{"id":55001375,"date":"2022-08-01T00:00:00","date_gmt":"2022-08-04T18:10:56","guid":{"rendered":"http:\/\/access-im-unternehmen.aix-dev.de\/aiu\/?p=1375"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-30T00:00:00","slug":"Bestellposition_per_Datenmakro_ergaenzen","status":"publish","type":"post","link":"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/","title":{"rendered":"Bestellposition per Datenmakro erg&auml;nzen"},"content":{"rendered":"<p><b>Bestellpositionen speichern wir in einer eigenen Tabelle beispielsweise namens tblBe-stellpositionen, die als m:n-Verkn&uuml;pfungstabelle zwischen Tabellen wie tblBestellungen und tblProdukte dient. Diese Tabelle nimmt dann jeweils noch Felder auf wie Einzelpreis, Mehrwertsteuersatz und Einheit, die wir aus der Produkte-Tabelle in die Bestellpositionen-Tabelle kopieren. Damit das automatisch beim Anlegen einer Bestellposition geschieht, f&uuml;gen wir normalerweise ein Ereignis zum Eingabeformular f&uuml;r die Bestellpositionen hinzu, das diese Daten ausliest und in die Bestellposition eintr&auml;gt. Es gibt jedoch noch eine Alternative: Dabei verwenden wir ein Datenmakro, das durch das Ereignis &#8222;Vor &Auml;nderung&#8220; des Datensatzes ausgel&ouml;st wird und verlegen die Logik damit in die Tabelle selbst. Wie das gelingt, zeigt der vorliegende Beitrag.<\/b><\/p>\n<h2>Beteiligte Tabellen<\/h2>\n<p>Die hier vorgestellte L&ouml;sung soll dazu dienen, die Daten aus mehreren Tabellen zum Zwecke der Archivierung direkt in die Tabelle <b>tblBestellpositionen <\/b>zu schreiben. Der Hintergrund ist, dass sich die Daten von Produkten wie Einzelpreis und Mehrwertsteuersatz sowie die Einheiten immer mal &auml;ndern k&ouml;nnen. Wenn wir diese Informationen dann nicht mit einer Bestellposition gespeichert haben und zu einem sp&auml;teren Zeitpunkt beispielsweise die Ums&auml;tze f&uuml;r einen Zeitraum in der Vergangenheit untersuchen wollen, m&uuml;ssen wir die Daten aus den Tabellen <b>tblBestellpositionen<\/b>, <b>tblProdukte <\/b>und <b>tblMehrwertsteuersaetze <\/b>zusammensuchen. Das Problem dabei ist, dass die Daten in diesen Tabellen sich mittlerweile ge&auml;ndert haben k&ouml;nnten und wir nicht die in diesem Zeitraum tats&auml;chlich g&uuml;ltigen Preise und Mehrwertsteuers&auml;tze ber&uuml;cksichtigen k&ouml;nnen.<\/p>\n<p>Die an dieser Situation beteiligten Tabellen sehen Sie in Bild 1.<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_001.png\" alt=\"Beteiligte Tabellen dieser L&ouml;sung\" width=\"700\" height=\"285,4934\"\/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 1: Beteiligte Tabellen dieser L&ouml;sung<\/span><\/b><\/p>\n<p>Damit das geschilderte Problem nicht auftritt und wir zu jedem Zeitpunkt die tats&auml;chlichen Ums&auml;tze f&uuml;r die jeweiligen Rechnungspositionen zusammentragen k&ouml;nnen, m&uuml;ssen wir die zu diesem Zeitpunkt g&uuml;ltigen Preise und Mehrwertsteuers&auml;tze irgendwo speichern. Dazu nutzen wir die Verkn&uuml;pfungstabelle <b>tblBestellpositionen <\/b>und f&uuml;gen dieser drei Felder namens <b>Einzelpreis<\/b>, <b>Mehrwertsteuersatz <\/b>und <b>EinheitID <\/b>hinzu, die wir beim Hinzuf&uuml;gen einer Bestellposition aus den verkn&uuml;pften Tabellen f&uuml;llen. Zus&auml;tzlich finden Sie hier noch das Feld <b>Rabatt<\/b>, dass auch f&uuml;r jede Bestellposition individuell festgelegt werden kann.<\/p>\n<h2>&Uuml;bliche Vorgehensweise<\/h2>\n<p>Normalerweise w&uuml;rden Sie f&uuml;r das Hinzuf&uuml;gen der genannten Daten zu einer Bestellposition ein Ereignis nutzen, das nach dem Ausw&auml;hlen des entsprechenden Produkts ausgel&ouml;st wird.<\/p>\n<p>Dies geschieht in einem Formular etwa namens <b>frmBestellungen<\/b>, das an die Daten der Tabelle <b>tblBestellungen <\/b>gebunden ist. Dieses enth&auml;lt wiederum ein Unterformular namens <b>sfmBestellungen<\/b>, das die Daten der Tabelle <b>tblBestellpositionen <\/b>anzeigt, und zwar in der Datenblattansicht (siehe Bild 2).<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_002.png\" alt=\"Formular zum Verwalten von Bestellungen und Bestellpositionen\" width=\"649,559\" height=\"316,197\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 2: Formular zum Verwalten von Bestellungen und Bestellpositionen<\/span><\/b><\/p>\n<p>Dieses Unterformular zeigt alle Felder der Tabelle <b>tblBestellpositionen <\/b>mit Ausnahme des Prim&auml;rschl&uuml;sselfeldes <b>ID <\/b>und des Fremdschl&uuml;sselfeldes <b>BestellungID <\/b>an. Die Daten des Unterformulars werden &uuml;ber dieses Fremdschl&uuml;sselfeld mit dem Feld <b>ID <\/b>des Datensatzes im &uuml;bergeordneten Formular <b>frmBestellungen <\/b>verkn&uuml;pft, sodass das Unterformular immer nur die zur aktuellen Bestellung geh&ouml;renden Bestellpositionen anzeigt. Durch diese Verkn&uuml;pfung erhalten au&szlig;erdem neu angelegte Bestellpositionen automatisch den Wert des Feldes <b>ID <\/b>der Bestellung im Hauptformular als Wert f&uuml;r das Fremdschl&uuml;sselfeld <b>BestellungID<\/b> der Tabelle <b>tblBestellpositionen<\/b>.<\/p>\n<p>Damit nach der Auswahl eines neuen Produkts aus dem Nachschlagefeld <b>ProduktID <\/b>im Unterformular direkt die Daten aus den verkn&uuml;pften Tabellen in den aktuellen Datensatz geschrieben werden, hinterlegen wir eine Ereignisprozedur f&uuml;r das Ereignis <b>Vor Aktualisierung <\/b>des Nachschlagefeldes. Dieses haben wir zu diesem Zweck in <b>cboProduktID <\/b>umbenannt.<\/p>\n<p>Die Prozedur finden Sie in Listing 1. Sie deklariert eine <b>Database<\/b>-Objektvariable, die wir mit einem Verweis auf das aktuelle <b>Database<\/b>-Objekt f&uuml;llen sowie eine Variable f&uuml;r ein <b>Recordset<\/b>-Objekt, das auf die Daten der Tabelle <b>tblProdukte <\/b>verweisen soll &#8211; hier genau auf den Datensatz, den der Benutzer mit dem Kombinationsfeld <b>cboProduktID <\/b>ausgew&auml;hlt hat.<\/p>\n<pre><span style=\"color:blue;\">Private Sub <\/span>cboProduktID_BeforeUpdate(Cancel<span style=\"color:blue;\"> As Integer<\/span>)\r\n     <span style=\"color:blue;\">Dim <\/span>db<span style=\"color:blue;\"> As <\/span>DAO.Database\r\n     <span style=\"color:blue;\">Dim <\/span>rstProdukte<span style=\"color:blue;\"> As <\/span>DAO.Recordset\r\n     <span style=\"color:blue;\">Dim <\/span>curMehrwertsteuersatz<span style=\"color:blue;\"> As Currency<\/span>\r\n     <span style=\"color:blue;\">Set<\/span> db = CurrentDb\r\n     <span style=\"color:blue;\">Set<\/span> rstProdukte = db.OpenRecordset(\"SELECT * FROM tblProdukte WHERE ID = \" & Me!ProduktID, dbOpenDynaset)\r\n     Me!Einzelpreis = rstProdukte!Einzelpreis\r\n     Me!EinheitID = rstProdukte!EinheitID\r\n     curMehrwertsteuersatz = DLookup(\"Mehrwertsteuersatzwert\", \"tblMehrwertsteuersaetze\", \"ID = \" _\r\n         & rstProdukte!MehrwertsteuersatzID)\r\n     Me!Mehrwertsteuersatz = curMehrwertsteuersatz\r\n<span style=\"color:blue;\">End Sub<\/span><\/pre>\n<p><b><span style=\"color:darkgrey;\">Listing 1: Ereignisprozedur beim Ausw&auml;hlen eines Produkts f&uuml;r eine Bestellposition<\/span><\/b><\/p>\n<p>Nach dem Ermitteln dieses Datensatzes schreibt die Prozedur die Werte der Felder <b>Einzelpreis <\/b>und <b>EinheitID <\/b>dieses Datensatzes in die entsprechenden Felder des aktuell im Unterformular angezeigten Datensatzes der Tabelle <b>tblBestellpositionen<\/b>. Schlie&szlig;lich ermittelt sie noch mit einer <b>DLookup<\/b>-Funktion den <b>Mehrwertsteuersatzwert <\/b>aus der Tabelle <b>tblMehrwertsteuersaetze <\/b>f&uuml;r die <b>MehrwertsteuersatzID <\/b>des gew&auml;hlten Produkts.<\/p>\n<p><!--30percent--><\/p>\n<p>Das Ergebnis dieser Abfrage landet in der Variablen <b>curMehrwertsteuersatzwert <\/b>und von dort im Feld <b>Mehrwertsteuersatz <\/b>der Bestellposition.<\/p>\n<p>W&auml;hlt der Benutzer nun eines der Produkte aus, werden die Felder automatisch wie in Bild 3 mit den gew&uuml;nschten Daten gef&uuml;llt.<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_003.png\" alt=\"Erg&auml;nzte Daten einer Bestellposition\" width=\"649,559\" height=\"316,197\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 3: Erg&auml;nzte Daten einer Bestellposition<\/span><\/b><\/p>\n<p>Bevor wir nun die Alternative ausprobieren, sollten Sie die Ereignisprozedur <b>cboProduktID_BeforeUpdate <\/b>wieder entfernen oder zumindest auskommentieren &#8211; anderenfalls bearbeiten wir die gleichen Felder durch zwei unterschiedliche Mechanismen und k&ouml;nnen die Ergebnisse nicht mehr sauber interpretieren.<\/p>\n<h2>Bestellpositionen erweitern per Datenmakro<\/h2>\n<p>Das hier beschriebene Verhalten wollen wir nun mit einem Datenmakro f&uuml;r die Tabelle <b>tblBestellpositionen <\/b>abbilden.<\/p>\n<p>Die Datenmakros von Access arbeiten so &auml;hnlich wie die Trigger, die Sie vielleicht vom SQL Server kennen. Dort gibt es die M&ouml;glichkeit, f&uuml;r bestimmte Aktionen wie das Anlegen, &Auml;ndern oder L&ouml;schen von Daten Ereignisse zu definieren, die wiederum &Auml;nderungen an Daten vornehmen oder andere Aktionen ausl&ouml;sen k&ouml;nnen.<\/p>\n<p>Access bietet gleich f&uuml;nf solcher Ereignisse an, die wir hier nicht im Detail auflisten wollen &#8211; denn wir ben&ouml;tigen nur eines davon. Dieses hei&szlig;t <b>Vor &Auml;nderung<\/b>.<\/p>\n<p>Es gibt zwei M&ouml;glichkeiten, durch Ereignisse ausgel&ouml;ste Datenmakros anzulegen. Die erste finden Sie in der Entwurfsansicht einer Tabelle, wenn Sie im Ribbon unter <b>Tabellenentwurf <\/b>die Schaltfl&auml;che <b>Datenmakro erstellen <\/b>anklicken. Dies &ouml;ffnet eine Liste der verf&uuml;gbaren Datenmakros (siehe Bild 4). Diese M&ouml;glichkeit k&ouml;nnen Sie nutzen, allerdings m&uuml;ssen Sie zum Ausprobieren jedesmal zur&uuml;ck zur Datenblattansicht wechseln, dort testen und dann f&uuml;r notwendige Korrekturen wieder zur&uuml;ckwechseln.<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_005.png\" alt=\"Anlegen eines Datenmakros per Ribbonbefehl aus der Entwurfsansicht einer Tabelle\" width=\"699,559\" height=\"322,058\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 4: Anlegen eines Datenmakros per Ribbonbefehl aus der Entwurfsansicht einer Tabelle<\/span><\/b><\/p>\n<p>Wesentlich produktiver finden wir dagegen die M&ouml;glichkeit, Datenmakros direkt von der Datenblattansicht aus zu manipulieren. Dazu aktivieren Sie bei ge&ouml;ffneter Tabelle im Ribbon die Registerseite Tabelle. Hier finden Sie die Befehle zum Anzeigen der verschiedenen Datenmakros direkt im Ribbon und m&uuml;ssen nicht erst noch eine Liste aufklappen, um die Befehle auszuf&uuml;hren (siehe Bild 5). Der Hauptpunkt dieser Variante ist jedoch, dass Sie das Datenmakro nach &Auml;nderungen direkt in der aktuellen Ansicht ausprobieren k&ouml;nnen und nicht erst noch von der Entwurfsansicht in die Datenblattansicht wechseln m&uuml;ssen.<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_004.png\" alt=\"Anlegen eines Datenmakros per Ribbonbefehl aus der Datenblattansicht einer Tabelle\" width=\"700\" height=\"303,6297\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 5: Anlegen eines Datenmakros per Ribbonbefehl aus der Datenblattansicht einer Tabelle<\/span><\/b><\/p>\n<h2>Anlegen eines Datenmakros f&uuml;r die Aktion &#8222;Vor &Auml;nderung&#8220;<\/h2>\n<p>Wir ben&ouml;tigen das Datenmakro, das durch die Aktion <b>Vor &Auml;nderung <\/b>ausgel&ouml;st wird. Warum nicht <b>Nach Aktualisierung<\/b>? Weil wir w&auml;hrend der Ausf&uuml;hrung des Makros noch &Auml;nderungen am aktuellen Datensatz vornehmen wollen. Wenn wir das Ereignis <b>Nach Aktualisierung <\/b>w&auml;hlen w&uuml;rden und darin Daten im aktuellen Datensatz &auml;ndern, w&uuml;rden wir dieses Ereignis immer wieder neu ausl&ouml;sen, weil wir ja immer wieder Daten &auml;ndern.<\/p>\n<h2>Aktionen nur beim Aktualisieren der ProduktID ausf&uuml;hren<\/h2>\n<p>Bevor wir beginnen, die Aktionen, die wir oben per VBA programmiert haben, im Makro nachzubilden, wollen wir zun&auml;chst eine wichtige Bedingung festlegen: Wir wollen die verkn&uuml;pften Daten n&auml;mlich nur nachtr&auml;glich in die Tabelle <b>tblBestellpositionen <\/b>schreiben, wenn der Benutzer ein neues Produkt f&uuml;r die Bestellposition ausgew&auml;hlt hat. Wenn er andere Felder &auml;ndert, beispielsweise die Menge, den Einzelpreis oder den Rabatt, soll nichts geschehen.<\/p>\n<p>Also legen wir als Erstes eine Bedingung fest, indem wir die Makroaktion <b>Wenn <\/b>hinzuf&uuml;gen (siehe Bild 6).<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_008.png\" alt=\"Hinzuf&uuml;gen einer Wenn-Aktion\" width=\"449,5589\" height=\"283,4175\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 6: Hinzuf&uuml;gen einer Wenn-Aktion<\/span><\/b><\/p>\n<p>F&uuml;r diese definieren wir als Kriterium den Ausdruck <b>Aktualisiert(&#8222;ProduktID&#8220;)<\/b>. Die Funktion <b>Aktualisiert <\/b>ist eine speziell f&uuml;r Datenmakros vorgesehene Funktion, die auch noch nicht mal in allen Datenmakros verf&uuml;gbar ist. Hier geben Sie den Namen des zu untersuchenden Feldes in Anf&uuml;hrungszeichen an (siehe Bild 7). Wurde seit dem letzten Speichern des Datensatzes nun das Feld <b>ProduktID <\/b>bearbeitet, dann werden die innerhalb des <b>Wenn<\/b>-Konstrukts enthaltenen Anweisungen ebenfalls ausgef&uuml;hrt.<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_009.png\" alt=\"Hinzuf&uuml;gen der Bedingung\" width=\"524,559\" height=\"191,9778\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 7: Hinzuf&uuml;gen der Bedingung<\/span><\/b><\/p>\n<h2>Datensatz f&uuml;r das hinzugef&uuml;gte Produkt ermitteln<\/h2>\n<p>Wir wollen nun, &auml;hnlich wie in der VBA-Prozedur, einen Datensatz ermitteln mit den Daten des hier referenzierten Eintrags der Tabelle <b>tblProdukte<\/b>. Dazu f&uuml;gen wir innerhalb der <b>Wenn<\/b>-Bedingung mit <b>Neue Aktion hinzuf&uuml;gen <\/b>die Aktion <b>Nachschlagen Datensatz <\/b>hinzu (die dann als <b>Datensatz nachschlagen in <\/b>erscheint). Hier geben wir unter <b>Datensatz nachschlagen in <\/b>den Namen der Tabelle <b>tblProdukte <\/b>ein.<\/p>\n<p>Dann legen wir einen Alias fest, indem wir auf den Link <b>Alias hinzuf&uuml;gen <\/b>klicken. Dieser soll, analog zur VBA-Prozedur, <b>rstProdukte <\/b>hei&szlig;en. Damit der richtige Datensatz ausgew&auml;hlt wird, geben wir als Bedingung den Ausdruck <b>[rstProdukte].[ID]=[tblBestellpositionen].[ProduktID] <\/b>ein. Damit k&ouml;nnen wir nun &uuml;ber den Alias <b>rstProdukte <\/b>auf den Datensatz der Tabelle <b>tblProdukte <\/b>zugreifen, den der Benutzer mit dem Nachschlagefeld <b>ProduktID <\/b>ausgew&auml;hlt hat (siehe Bild 8).<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_010.png\" alt=\"Nachschlagen eines Datensatzes\" width=\"599,559\" height=\"294,0735\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 8: Nachschlagen eines Datensatzes<\/span><\/b><\/p>\n<h2>Einzelpreis einstellen<\/h2>\n<p>Direkt unterhalb der <b>Nachschlagen Datensatz<\/b>-Aktion f&uuml;gen wir nun die Aktion <b>FestlegenFeld <\/b>ein. Mit dem Parameter <b>Name <\/b>stellen wir das zu &auml;ndernde Feld ein, in diesem Fall <b>[tblBestellpositionen].[Einzelpreis]<\/b>. Mit <b>Wert <\/b>stellen wir den Ausdruck ein, aus dem wir den neuen Wert aus dem Feld Einzelpreis des mit dem Alias <b>rstProdukte <\/b>versehenen Datensatzes lesen &#8211; also <b>[rstProdukte].[Einzelpreis]<\/b> (siehe Bild 9).<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_011.png\" alt=\"Festlegen eines Feldwertes\" width=\"599,559\" height=\"335,0476\"\/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 9: Festlegen eines Feldwertes<\/span><\/b><\/p>\n<h2>Erster Test<\/h2>\n<p>Bevor wir nun weitermachen, k&ouml;nnen wir die bisher definierte Funktion ausprobieren. Dazu schlie&szlig;en Sie den Makro-Editor und w&auml;hlen f&uuml;r einen Datensatz ein neues Produkt aus. Nach dem Wechsel zu einem anderen Datensatz erscheint wie gew&uuml;nscht der Preis f&uuml;r das gew&auml;hlte Produkt im Feld <b>Einzelpreis <\/b>(siehe Bild 10).<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_012.png\" alt=\"Ausprobieren des ersten Teils des Makros\" width=\"499,5589\" height=\"159,4977\"\/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 10: Ausprobieren des ersten Teils des Makros<\/span><\/b><\/p>\n<h2>Festlegen der Einheit programmieren<\/h2>\n<p>Um den Wert des Feldes <b>EinheitID <\/b>f&uuml;r die neue Bestellposition zu definieren, ben&ouml;tigen wir eine neue <b>FestlegenFeld<\/b>-Makroaktion analog zu der f&uuml;r den Einzelpreis. Am schnellsten legen Sie diese an, indem Sie die bereits bestehende Makroaktion durch einen Klick auf <b>FestlegenFeld <\/b>markieren und diese mit <b>Strg + C <\/b>und <b>Strg + V <\/b>kopieren. Danach ersetzen Sie nur beide Vorkommen von <b>Einzelpreis <\/b>durch <b>EinheitID <\/b>und schon wird beim n&auml;chsten Test auch die Einheit f&uuml;r das jeweilige Produkt in den Datensatz mit der Bestellposition eingetragen.<\/p>\n<h2>Mehrwertsteuersatz eintragen<\/h2>\n<p>Etwas aufwendiger ist das Eintragen des Mehrwertsteuersatzes. Hier m&uuml;ssen wir, wie auch in der VBA-Prozedur, zun&auml;chst auf eine weitere Tabelle zugreifen, um dann den ben&ouml;tigten Feldinhalt daraus zu ermitteln.<\/p>\n<p>Also erstellen wir unterhalb der soeben definierten <b>FestlegenFeld<\/b>-Makroaktion eine weitere Aktion namens <b>NachschlagenDatensatz<\/b>. Hier f&uuml;gen wir mit <b>Alias hinzuf&uuml;gen <\/b>wieder einen Alias hinzu, diesmal namens <b>rstMehrwertsteuersaetze<\/b>. Wir wollen den Datensatz nachschlagen in der Tabelle <b>tblMehrwertsteuersaetze<\/b>, und zwar mit der Bedingung <b>[rstMehrwertsteuersaetze].[ID]=[rstProdukte].[MehrwertsteuersatzID]<\/b>.<\/p>\n<p>Aus diesem Alias entnehmen wir mit der n&auml;chsten <b>FestlegenFeld<\/b>-Aktion den Wert des Feldes <b>Mehrwertsteuersatzwert <\/b>und tragen diesen f&uuml;r das Feld <b>Mehrwertsteuersatz <\/b>der Tabelle <b>tblBestellpositionen <\/b>ein.<\/p>\n<p>Das vollst&auml;ndige Makro sieht nun wie in Bild 11 aus.<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_013.png\" alt=\"Das vollst&auml;ndige Makro\" width=\"674,559\" height=\"552,7405\"\/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 11: Das vollst&auml;ndige Makro<\/span><\/b><\/p>\n<p>Probieren wir dieses nun aus, stellen wir fest, dass es wie gew&uuml;nscht funktioniert und die Daten aus den verkn&uuml;pften Tabellen in die Tabelle <b>tblBestellposition <\/b>schreibt.<\/p>\n<h2>M&ouml;gliche Fehler finden<\/h2>\n<p>Bei der Entwicklung dieses Makros sind beim Ausprobieren der verschiedenen Schritte Probleme aufgetaucht &#8211; der Name des f&uuml;r die Funktion <b>Aktualisiert <\/b>angegebenen Feldes in der <b>Wenn<\/b>-Anweisung war nicht in Anf&uuml;hrungszeichen eingefasst, eckige Klammern fehlten, statt des Punktes zwischen Tabelle und Feldname haben wir das Ausrufezeichen verwendet und so weiter.<\/p>\n<p>Wie kann man solche Fehler beim Programmieren von Datenmakros aufdecken? Manche davon, wie etwa das Verwenden von Ausrufezeichen statt des Punktes in Ausdr&uuml;cken wie <b>[rstProdukt]![Einzelpreis]<\/b>, werden direkt in Form einer Meldung bem&auml;ngelt (siehe Bild 12).<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2022_04\/pic_1375_014.png\" alt=\"Meldung eines offensichtlichen Fehlers\" width=\"499,5589\" height=\"238,3636\"\/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 12: Meldung eines offensichtlichen Fehlers<\/span><\/b><\/p>\n<p>Auch auf die Angabe des Feldnamens ohne Anf&uuml;hrungszeichen f&uuml;r die <b>Aktualisiert<\/b>-Funktion hat Access direkt per Fehlermeldung aufmerksam gemacht.<\/p>\n<h2>Downloads zu diesem Beitrag<\/h2>\n<p>Enthaltene Beispieldateien:<\/p>\n<p>Rechnungsbericht_Datenmakro.accdb<\/p>\n<p><a href=\"..\/fileadmin\/beispiele\/FF530AE2-6AE6-45AB-835A-96F7513052B9\/aiu_1375.zip\">Download<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Bestellpositionen speichern wir in einer eigenen Tabelle beispielsweise namens tblBe-stellpositionen, die als m:n-Verkn&uuml;pfungstabelle zwischen Tabellen wie tblBestellungen und tblProdukte dient. Diese Tabelle nimmt dann jeweils noch Felder auf wie Einzelpreis, Mehrwertsteuersatz und Einheit, die wir aus der Produkte-Tabelle in die Bestellpositionen-Tabelle kopieren. Damit das automatisch beim Anlegen einer Bestellposition geschieht, f&uuml;gen wir normalerweise ein Ereignis zum Eingabeformular f&uuml;r die Bestellpositionen hinzu, das diese Daten ausliest und in die Bestellposition eintr&auml;gt. Es gibt jedoch noch eine Alternative: Dabei verwenden wir ein Datenmakro, das durch das Ereignis &#8222;Vor &Auml;nderung&#8220; des Datensatzes ausgel&ouml;st wird und verlegen die Logik damit in die Tabelle selbst. Wie das gelingt, zeigt der vorliegende Beitrag.<\/p>\n","protected":false},"author":1,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"om_disable_all_campaigns":false,"_monsterinsights_skip_tracking":false,"_monsterinsights_sitenote_active":false,"_monsterinsights_sitenote_note":"","_monsterinsights_sitenote_category":0,"_uf_show_specific_survey":0,"_uf_disable_surveys":false,"footnotes":""},"categories":[662022,66042022,44000021],"tags":[],"class_list":["post-55001375","post","type-post","status-publish","format-standard","hentry","category-662022","category-66042022","category-Tabellen_und_Datenmodellierung"],"yoast_head":"<!-- This site is optimized with the Yoast SEO Premium plugin v20.9 (Yoast SEO v27.3) - https:\/\/yoast.com\/product\/yoast-seo-premium-wordpress\/ -->\n<title>Bestellposition per Datenmakro erg&auml;nzen - Access im Unternehmen<\/title>\n<meta name=\"robots\" content=\"index, follow, max-snippet:-1, max-image-preview:large, max-video-preview:-1\" \/>\n<link rel=\"canonical\" href=\"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/\" \/>\n<meta property=\"og:locale\" content=\"de_DE\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Bestellposition per Datenmakro erg&auml;nzen\" \/>\n<meta property=\"og:description\" content=\"Bestellpositionen speichern wir in einer eigenen Tabelle beispielsweise namens tblBe-stellpositionen, die als m:n-Verkn&uuml;pfungstabelle zwischen Tabellen wie tblBestellungen und tblProdukte dient. Diese Tabelle nimmt dann jeweils noch Felder auf wie Einzelpreis, Mehrwertsteuersatz und Einheit, die wir aus der Produkte-Tabelle in die Bestellpositionen-Tabelle kopieren. Damit das automatisch beim Anlegen einer Bestellposition geschieht, f&uuml;gen wir normalerweise ein Ereignis zum Eingabeformular f&uuml;r die Bestellpositionen hinzu, das diese Daten ausliest und in die Bestellposition eintr&auml;gt. Es gibt jedoch noch eine Alternative: Dabei verwenden wir ein Datenmakro, das durch das Ereignis &quot;Vor &Auml;nderung&quot; des Datensatzes ausgel&ouml;st wird und verlegen die Logik damit in die Tabelle selbst. Wie das gelingt, zeigt der vorliegende Beitrag.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/\" \/>\n<meta property=\"og:site_name\" content=\"Access im Unternehmen\" \/>\n<meta property=\"article:published_time\" content=\"2022-08-04T18:10:56+00:00\" \/>\n<meta name=\"author\" content=\"Andr\u00e9 Minhorst\" \/>\n<meta name=\"twitter:card\" content=\"summary_large_image\" \/>\n<meta name=\"twitter:label1\" content=\"Verfasst von\" \/>\n\t<meta name=\"twitter:data1\" content=\"Andr\u00e9 Minhorst\" \/>\n\t<meta name=\"twitter:label2\" content=\"Gesch\u00e4tzte Lesezeit\" \/>\n\t<meta name=\"twitter:data2\" content=\"11\u00a0Minuten\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Bestellposition_per_Datenmakro_ergaenzen\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Bestellposition_per_Datenmakro_ergaenzen\\\/\"},\"author\":{\"name\":\"Andr\u00e9 Minhorst\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#\\\/schema\\\/person\\\/13395c4bcd7d7963efe33be9c584d93f\"},\"headline\":\"Bestellposition per Datenmakro erg&auml;nzen\",\"datePublished\":\"2022-08-04T18:10:56+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Bestellposition_per_Datenmakro_ergaenzen\\\/\"},\"wordCount\":2104,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#organization\"},\"articleSection\":[\"2022\",\"4\\\/2022\",\"Tabellen und Datenmodellierung\"],\"inLanguage\":\"de\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/access-im-unternehmen.de\\\/Bestellposition_per_Datenmakro_ergaenzen\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Bestellposition_per_Datenmakro_ergaenzen\\\/\",\"url\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Bestellposition_per_Datenmakro_ergaenzen\\\/\",\"name\":\"Bestellposition per Datenmakro erg&auml;nzen - Access im Unternehmen\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#website\"},\"datePublished\":\"2022-08-04T18:10:56+00:00\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Bestellposition_per_Datenmakro_ergaenzen\\\/#breadcrumb\"},\"inLanguage\":\"de\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/access-im-unternehmen.de\\\/Bestellposition_per_Datenmakro_ergaenzen\\\/\"]}]},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Bestellposition_per_Datenmakro_ergaenzen\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/access-im-unternehmen.de\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Bestellposition per Datenmakro erg&auml;nzen\"}]},{\"@type\":\"WebSite\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#website\",\"url\":\"https:\\\/\\\/access-im-unternehmen.de\\\/\",\"name\":\"Access im Unternehmen\",\"description\":\"Das Magazin f\u00fcr Datenbankentwickler auf Basis von Microsoft Access\",\"publisher\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#organization\"},\"potentialAction\":[{\"@type\":\"SearchAction\",\"target\":{\"@type\":\"EntryPoint\",\"urlTemplate\":\"https:\\\/\\\/access-im-unternehmen.de\\\/?s={search_term_string}\"},\"query-input\":{\"@type\":\"PropertyValueSpecification\",\"valueRequired\":true,\"valueName\":\"search_term_string\"}}],\"inLanguage\":\"de\"},{\"@type\":\"Organization\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#organization\",\"name\":\"Andr\u00e9 Minhorst Verlag\",\"url\":\"https:\\\/\\\/access-im-unternehmen.de\\\/\",\"logo\":{\"@type\":\"ImageObject\",\"inLanguage\":\"de\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#\\\/schema\\\/logo\\\/image\\\/\",\"url\":\"https:\\\/\\\/access-im-unternehmen.de\\\/wp-content\\\/uploads\\\/2019\\\/09\\\/aiu_wp.png\",\"contentUrl\":\"https:\\\/\\\/access-im-unternehmen.de\\\/wp-content\\\/uploads\\\/2019\\\/09\\\/aiu_wp.png\",\"width\":370,\"height\":111,\"caption\":\"Andr\u00e9 Minhorst Verlag\"},\"image\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#\\\/schema\\\/logo\\\/image\\\/\"}},{\"@type\":\"Person\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#\\\/schema\\\/person\\\/13395c4bcd7d7963efe33be9c584d93f\",\"name\":\"Andr\u00e9 Minhorst\",\"image\":{\"@type\":\"ImageObject\",\"inLanguage\":\"de\",\"@id\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/1b9d010cf1716692cb9c34f21554e07d17d461acaea5b61b8cb21cbec678d48a?s=96&d=mm&r=g\",\"url\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/1b9d010cf1716692cb9c34f21554e07d17d461acaea5b61b8cb21cbec678d48a?s=96&d=mm&r=g\",\"contentUrl\":\"https:\\\/\\\/secure.gravatar.com\\\/avatar\\\/1b9d010cf1716692cb9c34f21554e07d17d461acaea5b61b8cb21cbec678d48a?s=96&d=mm&r=g\",\"caption\":\"Andr\u00e9 Minhorst\"}}]}<\/script>\n<!-- \/ Yoast SEO Premium plugin. -->","yoast_head_json":{"title":"Bestellposition per Datenmakro erg&auml;nzen - Access im Unternehmen","robots":{"index":"index","follow":"follow","max-snippet":"max-snippet:-1","max-image-preview":"max-image-preview:large","max-video-preview":"max-video-preview:-1"},"canonical":"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/","og_locale":"de_DE","og_type":"article","og_title":"Bestellposition per Datenmakro erg&auml;nzen","og_description":"Bestellpositionen speichern wir in einer eigenen Tabelle beispielsweise namens tblBe-stellpositionen, die als m:n-Verkn&uuml;pfungstabelle zwischen Tabellen wie tblBestellungen und tblProdukte dient. Diese Tabelle nimmt dann jeweils noch Felder auf wie Einzelpreis, Mehrwertsteuersatz und Einheit, die wir aus der Produkte-Tabelle in die Bestellpositionen-Tabelle kopieren. Damit das automatisch beim Anlegen einer Bestellposition geschieht, f&uuml;gen wir normalerweise ein Ereignis zum Eingabeformular f&uuml;r die Bestellpositionen hinzu, das diese Daten ausliest und in die Bestellposition eintr&auml;gt. Es gibt jedoch noch eine Alternative: Dabei verwenden wir ein Datenmakro, das durch das Ereignis \"Vor &Auml;nderung\" des Datensatzes ausgel&ouml;st wird und verlegen die Logik damit in die Tabelle selbst. Wie das gelingt, zeigt der vorliegende Beitrag.","og_url":"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/","og_site_name":"Access im Unternehmen","article_published_time":"2022-08-04T18:10:56+00:00","author":"Andr\u00e9 Minhorst","twitter_card":"summary_large_image","twitter_misc":{"Verfasst von":"Andr\u00e9 Minhorst","Gesch\u00e4tzte Lesezeit":"11\u00a0Minuten"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/#article","isPartOf":{"@id":"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/"},"author":{"name":"Andr\u00e9 Minhorst","@id":"https:\/\/access-im-unternehmen.de\/#\/schema\/person\/13395c4bcd7d7963efe33be9c584d93f"},"headline":"Bestellposition per Datenmakro erg&auml;nzen","datePublished":"2022-08-04T18:10:56+00:00","mainEntityOfPage":{"@id":"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/"},"wordCount":2104,"commentCount":0,"publisher":{"@id":"https:\/\/access-im-unternehmen.de\/#organization"},"articleSection":["2022","4\/2022","Tabellen und Datenmodellierung"],"inLanguage":"de","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/","url":"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/","name":"Bestellposition per Datenmakro erg&auml;nzen - Access im Unternehmen","isPartOf":{"@id":"https:\/\/access-im-unternehmen.de\/#website"},"datePublished":"2022-08-04T18:10:56+00:00","breadcrumb":{"@id":"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/#breadcrumb"},"inLanguage":"de","potentialAction":[{"@type":"ReadAction","target":["https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/"]}]},{"@type":"BreadcrumbList","@id":"https:\/\/access-im-unternehmen.de\/Bestellposition_per_Datenmakro_ergaenzen\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/access-im-unternehmen.de\/"},{"@type":"ListItem","position":2,"name":"Bestellposition per Datenmakro erg&auml;nzen"}]},{"@type":"WebSite","@id":"https:\/\/access-im-unternehmen.de\/#website","url":"https:\/\/access-im-unternehmen.de\/","name":"Access im Unternehmen","description":"Das Magazin f\u00fcr Datenbankentwickler auf Basis von Microsoft Access","publisher":{"@id":"https:\/\/access-im-unternehmen.de\/#organization"},"potentialAction":[{"@type":"SearchAction","target":{"@type":"EntryPoint","urlTemplate":"https:\/\/access-im-unternehmen.de\/?s={search_term_string}"},"query-input":{"@type":"PropertyValueSpecification","valueRequired":true,"valueName":"search_term_string"}}],"inLanguage":"de"},{"@type":"Organization","@id":"https:\/\/access-im-unternehmen.de\/#organization","name":"Andr\u00e9 Minhorst Verlag","url":"https:\/\/access-im-unternehmen.de\/","logo":{"@type":"ImageObject","inLanguage":"de","@id":"https:\/\/access-im-unternehmen.de\/#\/schema\/logo\/image\/","url":"https:\/\/access-im-unternehmen.de\/wp-content\/uploads\/2019\/09\/aiu_wp.png","contentUrl":"https:\/\/access-im-unternehmen.de\/wp-content\/uploads\/2019\/09\/aiu_wp.png","width":370,"height":111,"caption":"Andr\u00e9 Minhorst Verlag"},"image":{"@id":"https:\/\/access-im-unternehmen.de\/#\/schema\/logo\/image\/"}},{"@type":"Person","@id":"https:\/\/access-im-unternehmen.de\/#\/schema\/person\/13395c4bcd7d7963efe33be9c584d93f","name":"Andr\u00e9 Minhorst","image":{"@type":"ImageObject","inLanguage":"de","@id":"https:\/\/secure.gravatar.com\/avatar\/1b9d010cf1716692cb9c34f21554e07d17d461acaea5b61b8cb21cbec678d48a?s=96&d=mm&r=g","url":"https:\/\/secure.gravatar.com\/avatar\/1b9d010cf1716692cb9c34f21554e07d17d461acaea5b61b8cb21cbec678d48a?s=96&d=mm&r=g","contentUrl":"https:\/\/secure.gravatar.com\/avatar\/1b9d010cf1716692cb9c34f21554e07d17d461acaea5b61b8cb21cbec678d48a?s=96&d=mm&r=g","caption":"Andr\u00e9 Minhorst"}}]}},"_links":{"self":[{"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/posts\/55001375","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/users\/1"}],"replies":[{"embeddable":true,"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/comments?post=55001375"}],"version-history":[{"count":0,"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/posts\/55001375\/revisions"}],"wp:attachment":[{"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/media?parent=55001375"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/categories?post=55001375"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/tags?post=55001375"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}