{"id":55001012,"date":"2015-12-01T00:00:00","date_gmt":"2020-05-22T19:08:54","guid":{"rendered":"http:\/\/access-im-unternehmen.aix-dev.de\/aiu\/?p=1012"},"modified":"-0001-11-30T00:00:00","modified_gmt":"-0001-11-30T00:00:00","slug":"Drag_and_Drop_in_Anlagefelder","status":"publish","type":"post","link":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/","title":{"rendered":"Drag and Drop in Anlagefelder"},"content":{"rendered":"<p><img loading=\"lazy\" decoding=\"async\" src=\"http:\/\/vg07.met.vgwort.de\/na\/08f2414ba96341138f60497e7d1e522a\" width=\"1\" height=\"1\" alt=\"\"><\/p>\n<p><b>Mit den Anlagefeldern hat Microsoft unter Access 2007 eine M&ouml;glichkeit zum Speichern von Dateien in Tabellenfeldern eingef&uuml;hrt, die etwas einfacher zug&auml;nglich ist als das bis dahin f&uuml;r solche Zwecke verwendete OLE-Feld. Leider fehlt noch eine M&ouml;glichkeit, einfach per Drag and Drop eine Datei aus dem Windows Explorer in ein Anlagefeld einer Tabelle zu ziehen. Dieser Beitrag zeigt, wie Sie ein solches Feature nachtr&auml;glich hinzuf&uuml;gen k&ouml;nnen.<\/b><\/p>\n<p>Anlagefelder sind eigentlich eine prima Sache: Sie k&ouml;nnen ganz einfach &uuml;ber die Benutzeroberfl&auml;che Dateien hinzuf&uuml;gen und darauf ins Dateisystem &uuml;bertragen. Auch ein &ouml;ffnen der Dateien direkt aus dem Anlagefeld heraus ist m&ouml;glich. Allerdings ist der Zugriff auf die enthaltenen Dateien mitunter etwas m&uuml;hselig.<\/p>\n<p>Immerhin m&uuml;ssen Sie zun&auml;chst auf das Anlage-Steuerelement klicken und dann auf das erscheinende Men&uuml;, um &uuml;berhaupt erst die Liste der enthaltenen Dateien anzuzeigen (s. Bild 1).<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2015_06\/pic_1012_002.png\" alt=\"&ouml;ffnen des Dialogs zum Verwalten von Anlagen\" width=\"500\" height=\"205,9925\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 1: &ouml;ffnen des Dialogs zum Verwalten von Anlagen<\/span><\/b><\/p>\n<p>Dort erwartet Sie dann ein Dialog, der die im Anlagefeld enthaltenen Anlagen anzeigt und verschiedene M&ouml;glichkeiten bietet, zum Beispiel zum Hinzuf&uuml;gen, Entfernen oder &ouml;ffnen einer der im Anlagefeld gespeicherten Dateien (s. Bild 2).<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2015_06\/pic_1012_003.png\" alt=\"Dialog zum Verwalten von Anlagen\" width=\"600\" height=\"276,0355\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 2: Dialog zum Verwalten von Anlagen<\/span><\/b><\/p>\n<p>Was hier f&uuml;r einige Anwendungen fehlen d&uuml;rfte, ist eine M&ouml;glichkeit, mal eben eine Datei aus dem Windows Explorer auf ein Steuerelement zu ziehen und so die Datei im Anlagefeld zu speichern. Das stellen wir uns etwa wie in Bild 3 vor.<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2015_06\/pic_1012_001.png\" alt=\"Formular mit Drag-and-Drop-Ziel f&uuml;r das Anlagefeld\" width=\"425\" height=\"269,3416\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 3: Formular mit Drag-and-Drop-Ziel f&uuml;r das Anlagefeld<\/span><\/b><\/p>\n<p>Hier w&auml;hlen wir komfortabel die Zieltabelle und das darin enthaltene Anlagefeld aus. Das Listenfeld darunter zeigt alle Datens&auml;tze der Tabelle an. Hier markieren Sie den Datensatz, dem Sie eine Datei hinzuf&uuml;gen m&ouml;chten. Dann ziehen Sie die gew&uuml;nschte Datei aus dem Windows Explorer einfach auf das darunter befindliche <b>ListView<\/b>-Steuerelement. Das erfolgreiche Speichern wird noch durch eine kurze Meldung best&auml;tigt.<\/p>\n<h2>Formular f&uuml;r Drag und Drop<\/h2>\n<p>Das Formular der Beispieldatenbank hei&szlig;t <b>frmDragAndDrop <\/b>und soll zeigen, wie Sie Dateien flexibel in beliebige Anlagefelder hineinziehen k&ouml;nnen. Dies ist erstens sinnvoll, weil Sie so die relevanten Codezeilen leicht anpassen k&ouml;nnen, zweitens k&ouml;nnen Sie das Formular gleich nutzen,  wenn Sie einem Anlagefeld einer beliebigen Tabelle Dateien hinzuf&uuml;gen m&ouml;chten.<\/p>\n<p>In der Entwurfsansicht sieht das Formular wie in Bild 4 aus. Im oberen Bereich finden Sie die beiden Kombinationsfelder, mit denen Sie die Zieltabelle und das darin enthaltene Anlagefeld ausw&auml;hlen k&ouml;nnen. Darunter befindet sich ein Listenfeld, das die Inhalte der ersten vier Felder der gew&auml;hlten Tabelle anzeigt.<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2015_06\/pic_1012_004.png\" alt=\"Das Formular mit dem Drag-and-Drop-Ziel in der Entwurfsansicht\" width=\"500\" height=\"334,8135\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 4: Das Formular mit dem Drag-and-Drop-Ziel in der Entwurfsansicht<\/span><\/b><\/p>\n<p>Hier k&ouml;nnen Sie festlegen, zu welchem Datensatz die Anlage hinzugef&uuml;gt werden soll. Schlie&szlig;lich folgt das wichtigste Steuerelement &#8211; das <b>ListView<\/b>-Steuerelement, das als Drag-and-Drop-Ziel dient.<\/p>\n<p>Warum ausgerechnet ein <b>ListView<\/b>-Steuerelement Nun: Dieses bietet im Gegensatz zu den Standardsteuerelementen von Access die M&ouml;glichkeit, auf Drag-and-Drop-Ereignisse zu reagieren und diese zu implementieren.<\/p>\n<h2>Tabelle und Feld ausw&auml;hlen<\/h2>\n<p>Das Kombinationsfeld <b>cboTabellen <\/b>erh&auml;lt als Datenherkunft die folgende Abfrage:<\/p>\n<pre>SELECT Name FROM MSysObjects WHERE Type = 1 \r\nAND NOT Name LIKE ''MSys*'' AND NOT Name LIKE ''~*'' \r\nAND NOT Name LIKE ''f_*'' ORDER BY Name;<\/pre>\n<p>Diese liefert alle Eintr&auml;ge der Systemtabelle <b>MSysObjects<\/b>, deren Feld <b>Type <\/b>den Wert <b>1 <\/b>enth&auml;lt (f&uuml;r lokale Access-Tabellen) und deren Feld <b>Name <\/b>nicht mit <b>MSys&#8230;<\/b>, <b>F_&#8230;<\/b> oder <b>~&#8230;<\/b> beginnt. Erstere sind die Systemtabellen, Letztere f&uuml;r den internen Gebrauch verwendete Tabellen.<\/p>\n<p>Nach der Auswahl soll das zweite Kombinationsfeld die Felder der gew&auml;hlten Tabelle anzeigen.<\/p>\n<p>Dazu legen wir f&uuml;r <b>cboTabellen <\/b>eine Ereignisprozedur an, die durch das Ereignis <b>Nach Aktualisierung <\/b>ausgel&ouml;st wird:<\/p>\n<pre><span style=\"color:blue;\">Private Sub <\/span>cboTabellen_AfterUpdate()\r\n     Me!cboFelder.RowSource = Me!cboTabellen\r\n     Me!lstDatensaetze.RowSource = Me!cboTabellen\r\n<span style=\"color:blue;\">End Sub<\/span><\/pre>\n<p>Die erste Anweisung stellt die Datensatzherkunft des Kombinationsfeldes zur Anzeige der Felder auf den Wert des ersten Kombinationsfeldes ein, also den Namen der Tabelle.<\/p>\n<p>Die zweite legt die gleiche Tabelle als Datensatzherkunft des Listenfeldes <b>lstDatensaetze <\/b>zur Anzeige der enthaltenen Daten fest. Damit das zweite Kombinationsfeld nach der Angabe eines Tabellennamens als Datensatzherkunft auch die enthaltenen Felder anzeigt, stellen Sie zuvor noch die Eigenschaft <b>Herkunftsart<\/b> auf den Wert <b>Feldliste <\/b>ein (s. Bild 5).<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2015_06\/pic_1012_005.png\" alt=\"Einstellen der Herkunftsart f&uuml;r das Kombinationsfeld cboFelder\" width=\"600\" height=\"240,7583\" \/><\/p>\n<p><!--30percent--><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 5: Einstellen der Herkunftsart f&uuml;r das Kombinationsfeld cboFelder<\/span><\/b><\/p>\n<p>Fehlen noch einige Einstellungen f&uuml;r das <b>ListView<\/b>-Steuerelement. Diese nehmen wir gleich beim &ouml;ffnen des Formulars in der Ereignisprozedur <b>Beim Laden <\/b>vor.<\/p>\n<p>Diese Prozedur aus Listing 1 deklariert zun&auml;chst eine Variable des Datentyps <b>ColumnHeader<\/b>. Dieses ben&ouml;tigen wir gleich, um eine Referenz auf ein neu angelegtes Objekt dieses Typs zu speichern. Das <b>ListView<\/b>-Element enth&auml;lt n&auml;mlich nicht automatisch Spalten und somit auch keine Spaltenk&ouml;pfe.<\/p>\n<pre><span style=\"color:blue;\">Private Sub <\/span>Form_Load()\r\n     <span style=\"color:blue;\">Dim <\/span>objColumnheader<span style=\"color:blue;\"> As <\/span>MSComctlLib.ColumnHeader\r\n     <span style=\"color:blue;\">With<\/span> Me!ctlListview\r\n         .ColumnHeaders.Clear\r\n         <span style=\"color:blue;\">Set<\/span> objColumnheader = .ColumnHeaders.Add(, , \"Dateien hierher ziehen:\")\r\n         objColumnheader.Width = Me!ctlListview.Width - 100\r\n         .View = lvwReport\r\n         .OLEDropMode = ccOLEDropManual\r\n         .ListItems.Clear\r\n     End <span style=\"color:blue;\">With<\/span>\r\n<span style=\"color:blue;\">End Sub<\/span><\/pre>\n<p><b><span style=\"color:darkgrey;\">Listing 1: Einstellen des ListView-Steuerelements beim &ouml;ffnen des Formulars<\/span><\/b><\/p>\n<p>Nachdem die Prozedur eventuell noch vorhandene Spaltenk&ouml;pfe mit der <b>Clear<\/b>-Anweisung gel&ouml;scht hat, legt sie mit der <b>Add<\/b>-Methode der <b>ColumnHeaders<\/b>-Auflistung des <b>ListView<\/b>-Steuerelements <b>ctlListView <\/b>einen neuen Spaltenkopf an und legt &uuml;ber den dritten Parameter dieser Methode die Spaltenbeschriftung fest. Im Grunde ben&ouml;tigen wir ja gar keine Spalten, aber wir wollen im <b>ListView<\/b>-Steuerelement die Beschriftung Dateien hierher ziehen: unterbringen, damit der Benutzer wei&szlig;, was er mit dem <b>ListView<\/b>-Steuerelement anfangen kann.<\/p>\n<p>In der folgenden Anweisung stellen wir die Spaltenbreite f&uuml;r die neu erstellte und in der Variablen <b>objColumnheader <\/b>gespeicherten Spalte auf einen Wert ein, der etwas kleiner ist als die Breite des <b>ListView<\/b>-Steuerelements selbst. Schlie&szlig;lich legen wir noch die Ansicht auf <b>lvwReport <\/b>fest, damit der Spaltenkopf &uuml;berhaupt erscheint, und stellen <b>OLEDropMode <\/b>auf <b>ccOLEDropManual <\/b>ein, damit wir das Ereignis f&uuml;r das Droppen von Elementen selbst programmieren k&ouml;nnen.<\/p>\n<p>Die <b>ListItems.Clear<\/b>-Methode leert die Liste, falls diese aus irgendwelchen Gr&uuml;nden einen Eintrag enthalten sollte. Damit finden Sie das Formular in der Entwurfsansicht auch wie in der eingangs dargestellten Abbildung vor.<\/p>\n<h2>Drop-Ereignis<\/h2>\n<p>Wenn der Benutzer eine Datei &uuml;ber dem <b>ListView<\/b>-Steuerelement fallen l&auml;sst, l&ouml;st dies das Ereignis <b>OLEDragDrop <\/b>aus. Dieses Ereignis k&ouml;nnen Sie nicht, wie bei den eingebauten Access-Steuerelementen &uuml;blich, &uuml;ber das Eigenschaftsfenster des Steuerelements anlegen. Stattdessen &ouml;ffnen Sie direkt das Klassenmodul des Formulars. W&auml;hlen Sie dort im linken Kombinationsfeld im oberen Bereich den Wert <b>ctlListView <\/b>aus und im rechten <b>OLEDragDrop<\/b>. Der VBA-Editor legt nun die gew&uuml;nschte Ereignisprozedur an.<\/p>\n<p>Diese m&uuml;ssen Sie nun nur noch wie in Listing 2 auff&uuml;llen. Die Prozedur erwartet einen f&uuml;r uns wichtigen Parameter, n&auml;mlich <b>Data<\/b>. Dieses liefert eine Verweis auf das Objekt, das per Drag and Drop &uuml;ber dem <b>ListView<\/b>-Steuerelement fallen gelassen wurde.<\/p>\n<pre><span style=\"color:blue;\">Private Sub <\/span>ctlListview_OLEDragDrop(Data<span style=\"color:blue;\"> As Object<\/span>, Effect<span style=\"color:blue;\"> As Long<\/span>, _\r\n         Button<span style=\"color:blue;\"> As Integer<\/span>, Shift<span style=\"color:blue;\"> As Integer<\/span>, x<span style=\"color:blue;\"> As Single<\/span>, y<span style=\"color:blue;\"> As Single<\/span>)\r\n     <span style=\"color:blue;\">Dim <\/span>varDateipfad<span style=\"color:blue;\"> As Variant<\/span>\r\n     <span style=\"color:blue;\">Dim <\/span>strDateiname<span style=\"color:blue;\"> As String<\/span>\r\n     <span style=\"color:blue;\">If <\/span>Data.GetFormat(ccCFFiles)<span style=\"color:blue;\"> Then<\/span>\r\n         For Each varDateipfad In Data.Files\r\n             DateiSpeichern CStr(varDateipfad)\r\n             <span style=\"color:blue;\">MsgBox<\/span> \"Datei hinzugef&uuml;gt.\"\r\n         <span style=\"color:blue;\">Next<\/span>\r\n     <span style=\"color:blue;\">End If<\/span>\r\n<span style=\"color:blue;\">End Sub<\/span><\/pre>\n<p><b><span style=\"color:darkgrey;\">Listing 2: Ereignis, das beim Fallenlassen einer Datei &uuml;ber dem ListView-Steuerelement ausgel&ouml;st wird<\/span><\/b><\/p>\n<p><b>Data <\/b>kann eines oder mehrere Objekte enthalten. Deshalb durchlaufen wir in einer <b>For Each<\/b>-Schleife alle Eintr&auml;ge der <b>Files<\/b>-Auflistung des <b>Data<\/b>-Objekts. Dabei landet der Dateiname jeweils in der Variablen <b>varDateipfad<\/b>.<\/p>\n<p>Die Funktion <b>GetFormat <\/b>des <b>Data<\/b>-Objekts pr&uuml;ft, ob das Format der aktuellen Datei einem bestimmten Wert entspricht &#8211; in diesem Fall <b>ccDFFiles <\/b>f&uuml;r eine Datei.<\/p>\n<p>Ist dies der Fall, ruft die Prozedur die Routine <b>DateiSpeichern <\/b>auf und &uuml;bergibt dieser den Dateinamen aus der Variablen <b>varDateipfad<\/b>.<\/p>\n<h2>Datei im Anlagefeld speichern<\/h2>\n<p>Fehlt noch die Prozedur <b>DateiSpeichern<\/b>, die den Dateinamen als Parameter entgegennimmt (s. Listing 3). Diese ermittelt zun&auml;chst mit der Funktion <b>GetSinglePrimaryKey <\/b>den Prim&auml;rschl&uuml;ssel der Tabelle (siehe Artikel <b>Prim&auml;rschl&uuml;sselfelder ermitteln<\/b>, <b>www.access-im-unternehmen.de\/1004<\/b>).<\/p>\n<pre><span style=\"color:blue;\">Private Sub <\/span>DateiSpeichern(strDateiname<span style=\"color:blue;\"> As String<\/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>rst<span style=\"color:blue;\"> As <\/span>DAO.Recordset\r\n     <span style=\"color:blue;\">Dim <\/span>fld<span style=\"color:blue;\"> As <\/span>DAO.Field2\r\n     <span style=\"color:blue;\">Dim <\/span>rstDateien<span style=\"color:blue;\"> As <\/span>DAO.Recordset2\r\n     <span style=\"color:blue;\">Dim <\/span>strPK<span style=\"color:blue;\"> As String<\/span>\r\n     strPK = GetSinglePrimaryKey(Me!cboTabellen)\r\n     <span style=\"color:blue;\">Set<\/span> db = CurrentDb\r\n     <span style=\"color:blue;\">Set<\/span> rst = db.OpenRecordset(\"SELECT * FROM \" & Me!cboTabellen & \" WHERE \" & strPK _\r\n         & \" = \" & Me!lstDatensaetze, dbOpenDynaset)\r\n     rst.Edit\r\n     <span style=\"color:blue;\">Set<\/span> rstDateien = rst.Fields(Me!cboFelder).Value\r\n     rstDateien.Add<span style=\"color:blue;\">New<\/span>\r\n     <span style=\"color:blue;\">Set<\/span> fld = rstDateien.Fields(\"FileData\")\r\n     fld.LoadFromFile strDateiname\r\n     rstDateien.Update\r\n     rst.Update\r\n<span style=\"color:blue;\">End Sub<\/span><\/pre>\n<p><b><span style=\"color:darkgrey;\">Listing 3: Speichern einer Datei im Anlagefeld<\/span><\/b><\/p>\n<p>Anschlie&szlig;end liest die Prozedur die Daten der in <b>cboTabellen <\/b>angegebenen Tabelle in ein Recordset ein, wobei der Prim&auml;rschl&uuml;sselwert dem Wert der gebundenen Spalte des aktuell in <b>lstDatensaetze <\/b>markierten Eintrags entsprechen muss.<\/p>\n<p>Die folgende Anweisung startet die Bearbeitung dieses Datensatzes, die &uuml;bern&auml;chste weist dem <b>Recordset2<\/b>-Objekt den Inhalt des Feldes aus <b>cboFelder <\/b>zu &#8211; also den Inhalt des Anlagefeldes. Zur Erl&auml;uterung: Anlagefelder enthalten immer ein Recordset mit je einem Datensatz f&uuml;r jede gespeicherte Anlage.<\/p>\n<p>Dies wird auch deutlich, wenn Sie einmal eine Tabelle mit einem Anlagefeld in den Entwurf einer Abfrage ziehen &#8211; dort finden Sie versetzt zum Anlagefeld weitere Felder (s. Bild 6). Dies sind die Felder der verkn&uuml;pften, internen Tabelle, welche die eigentlichen Datens&auml;tze mit den Anlagen speichert. Die Tabelle enth&auml;lt die Felder <b>FileData<\/b>, <b>FileName <\/b>und <b>FileType<\/b>. <b>FileData<\/b> ist das Feld, das die Datei selbst enth&auml;lt.<\/p>\n<p class=\"image\"><img decoding=\"async\" src=\"..\/fileadmin\/_temp_\/2015_06\/pic_1012_006.png\" alt=\"Felder des Recordsets eines Anlagefeldes\" width=\"600\" height=\"421,6217\" \/><\/p>\n<p><b><span style=\"color:darkgrey;\">Bild 6: Felder des Recordsets eines Anlagefeldes<\/span><\/b><\/p>\n<p>Wie in der Prozedur k&ouml;nnen Sie nun &uuml;ber die <b>Value<\/b>-Eigenschaft des Anlagefeldes ein Recordset erstellen, das die verkn&uuml;pfte Tabelle mit den Anlagedaten enth&auml;lt. Diesem Recordset f&uuml;gen wir nun einen neuen Datensatz hinzu. Das Feld <b>FileData <\/b>referenzieren wir mit der Objektvariablen <b>fld <\/b>des Typs <b>Field2<\/b>. Dieses bietet wiederum die Methode <b>LoadFromFile <\/b>an, welche die als Parameter angegebene Datei in das Anlagefeld l&auml;dt. Um die &auml;nderungen zu speichern, rufen Sie erst die <b>Update<\/b>-Methode des Recordsets f&uuml;r das Anlagefeld auf und dann die <b>Update<\/b>-Methode f&uuml;r das Recordset auf Basis der Tabelle.<\/p>\n<h2>Zusammenfassung und Ausblick<\/h2>\n<p>Mit der in diesem Beitrag vorgestellten Technik k&ouml;nnen Sie Dateien aus dem Windows Explorer per Drag and Drop auf ein <b>ListView<\/b>-Steuerelement in einem Anlagefeld speichern. Das Beispiel in diesem Beitrag erlaubt es, die Tabelle und das Anlagefeld, das als Ziel verwendet werden soll, zur Laufzeit auszuw&auml;hlen.<\/p>\n<p>Die L&ouml;sung setzt voraus, dass die Tabelle mit dem Anlagefeld nur einen einfachen, aber keinen zusammengesetzten Prim&auml;rschl&uuml;ssel verwendet und dass diese das erste Feld der Tabelle ist &#8211; nur so wird dieses als erste und somit gebundene Spalte des Listenfeldes angezeigt, das zur Auswahl des Zieldatensatzes verwendet wird.<\/p>\n<p>In einem weiteren Beitrag zeigen wir, wie Sie die L&ouml;sung zum Hinzuf&uuml;gen und Verwalten der Inhalte von Anlagefeldern nutzen k&ouml;nnen. Dort sollen auch die bereits gespeicherten Dateien in einem <b>ListView<\/b>-Steuerelement angezeigt werden.<\/p>\n<p>Diese k&ouml;nnen Sie dann &uuml;ber ein Kontextmen&uuml; oder daf&uuml;r vorgesehene Schaltfl&auml;chen l&ouml;schen, &ouml;ffnen oder im Dateisystem speichern (<b>Inhalte von Anlagefeldern verwalten<\/b>, <b>www.access-im-unternehmen.de\/1013<\/b>).<\/p>\n<h3>Downloads zu diesem Beitrag<\/h3>\n<p>Enthaltene Beispieldateien:<\/p>\n<p>DragAndDrop.accdb<\/p>\n<p><a href=\"..\/fileadmin\/beispiele\/{72F27534-369C-4F59-97A3-C48BDEF0281C}\/aiu_1012.zip\">Download<\/a><\/p>\n","protected":false},"excerpt":{"rendered":"<p>Mit den Anlagefeldern hat Microsoft unter Access 2007 eine M&ouml;glichkeit zum Speichern von Dateien in Tabellenfeldern eingef&uuml;hrt, die etwas einfacher zug&auml;nglich ist als das bis dahin f&uuml;r solche Zwecke verwendete OLE-Feld. Leider fehlt noch eine M&ouml;glichkeit, einfach per Drag and Drop eine Datei aus dem Windows Explorer in ein Anlagefeld einer Tabelle zu ziehen. Dieser Beitrag zeigt, wie Sie ein solches Feature nachtr&auml;glich hinzuf&uuml;gen k&ouml;nnen.<\/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":[662015,66062015,44000023],"tags":[],"class_list":["post-55001012","post","type-post","status-publish","format-standard","hentry","category-662015","category-66062015","category-Mit_Formularen_arbeiten"],"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>Drag and Drop in Anlagefelder - 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\/Drag_and_Drop_in_Anlagefelder\/\" \/>\n<meta property=\"og:locale\" content=\"de_DE\" \/>\n<meta property=\"og:type\" content=\"article\" \/>\n<meta property=\"og:title\" content=\"Drag and Drop in Anlagefelder\" \/>\n<meta property=\"og:description\" content=\"Mit den Anlagefeldern hat Microsoft unter Access 2007 eine M&ouml;glichkeit zum Speichern von Dateien in Tabellenfeldern eingef&uuml;hrt, die etwas einfacher zug&auml;nglich ist als das bis dahin f&uuml;r solche Zwecke verwendete OLE-Feld. Leider fehlt noch eine M&ouml;glichkeit, einfach per Drag and Drop eine Datei aus dem Windows Explorer in ein Anlagefeld einer Tabelle zu ziehen. Dieser Beitrag zeigt, wie Sie ein solches Feature nachtr&auml;glich hinzuf&uuml;gen k&ouml;nnen.\" \/>\n<meta property=\"og:url\" content=\"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/\" \/>\n<meta property=\"og:site_name\" content=\"Access im Unternehmen\" \/>\n<meta property=\"article:published_time\" content=\"2020-05-22T19:08:54+00:00\" \/>\n<meta property=\"og:image\" content=\"http:\/\/vg07.met.vgwort.de\/na\/08f2414ba96341138f60497e7d1e522a\" \/>\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=\"10\u00a0Minuten\" \/>\n<script type=\"application\/ld+json\" class=\"yoast-schema-graph\">{\"@context\":\"https:\\\/\\\/schema.org\",\"@graph\":[{\"@type\":\"Article\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/#article\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/\"},\"author\":{\"name\":\"Andr\u00e9 Minhorst\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#\\\/schema\\\/person\\\/13395c4bcd7d7963efe33be9c584d93f\"},\"headline\":\"Drag and Drop in Anlagefelder\",\"datePublished\":\"2020-05-22T19:08:54+00:00\",\"mainEntityOfPage\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/\"},\"wordCount\":1705,\"commentCount\":0,\"publisher\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#organization\"},\"image\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/#primaryimage\"},\"thumbnailUrl\":\"http:\\\/\\\/vg07.met.vgwort.de\\\/na\\\/08f2414ba96341138f60497e7d1e522a\",\"articleSection\":[\"2015\",\"6\\\/2015\",\"Mit Formularen arbeiten\"],\"inLanguage\":\"de\",\"potentialAction\":[{\"@type\":\"CommentAction\",\"name\":\"Comment\",\"target\":[\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/#respond\"]}]},{\"@type\":\"WebPage\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/\",\"url\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/\",\"name\":\"Drag and Drop in Anlagefelder - Access im Unternehmen\",\"isPartOf\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/#website\"},\"primaryImageOfPage\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/#primaryimage\"},\"image\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/#primaryimage\"},\"thumbnailUrl\":\"http:\\\/\\\/vg07.met.vgwort.de\\\/na\\\/08f2414ba96341138f60497e7d1e522a\",\"datePublished\":\"2020-05-22T19:08:54+00:00\",\"breadcrumb\":{\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/#breadcrumb\"},\"inLanguage\":\"de\",\"potentialAction\":[{\"@type\":\"ReadAction\",\"target\":[\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/\"]}]},{\"@type\":\"ImageObject\",\"inLanguage\":\"de\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/#primaryimage\",\"url\":\"http:\\\/\\\/vg07.met.vgwort.de\\\/na\\\/08f2414ba96341138f60497e7d1e522a\",\"contentUrl\":\"http:\\\/\\\/vg07.met.vgwort.de\\\/na\\\/08f2414ba96341138f60497e7d1e522a\"},{\"@type\":\"BreadcrumbList\",\"@id\":\"https:\\\/\\\/access-im-unternehmen.de\\\/Drag_and_Drop_in_Anlagefelder\\\/#breadcrumb\",\"itemListElement\":[{\"@type\":\"ListItem\",\"position\":1,\"name\":\"Home\",\"item\":\"https:\\\/\\\/access-im-unternehmen.de\\\/\"},{\"@type\":\"ListItem\",\"position\":2,\"name\":\"Drag and Drop in Anlagefelder\"}]},{\"@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":"Drag and Drop in Anlagefelder - 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\/Drag_and_Drop_in_Anlagefelder\/","og_locale":"de_DE","og_type":"article","og_title":"Drag and Drop in Anlagefelder","og_description":"Mit den Anlagefeldern hat Microsoft unter Access 2007 eine M&ouml;glichkeit zum Speichern von Dateien in Tabellenfeldern eingef&uuml;hrt, die etwas einfacher zug&auml;nglich ist als das bis dahin f&uuml;r solche Zwecke verwendete OLE-Feld. Leider fehlt noch eine M&ouml;glichkeit, einfach per Drag and Drop eine Datei aus dem Windows Explorer in ein Anlagefeld einer Tabelle zu ziehen. Dieser Beitrag zeigt, wie Sie ein solches Feature nachtr&auml;glich hinzuf&uuml;gen k&ouml;nnen.","og_url":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/","og_site_name":"Access im Unternehmen","article_published_time":"2020-05-22T19:08:54+00:00","og_image":[{"url":"http:\/\/vg07.met.vgwort.de\/na\/08f2414ba96341138f60497e7d1e522a","type":"","width":"","height":""}],"author":"Andr\u00e9 Minhorst","twitter_card":"summary_large_image","twitter_misc":{"Verfasst von":"Andr\u00e9 Minhorst","Gesch\u00e4tzte Lesezeit":"10\u00a0Minuten"},"schema":{"@context":"https:\/\/schema.org","@graph":[{"@type":"Article","@id":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/#article","isPartOf":{"@id":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/"},"author":{"name":"Andr\u00e9 Minhorst","@id":"https:\/\/access-im-unternehmen.de\/#\/schema\/person\/13395c4bcd7d7963efe33be9c584d93f"},"headline":"Drag and Drop in Anlagefelder","datePublished":"2020-05-22T19:08:54+00:00","mainEntityOfPage":{"@id":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/"},"wordCount":1705,"commentCount":0,"publisher":{"@id":"https:\/\/access-im-unternehmen.de\/#organization"},"image":{"@id":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/#primaryimage"},"thumbnailUrl":"http:\/\/vg07.met.vgwort.de\/na\/08f2414ba96341138f60497e7d1e522a","articleSection":["2015","6\/2015","Mit Formularen arbeiten"],"inLanguage":"de","potentialAction":[{"@type":"CommentAction","name":"Comment","target":["https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/#respond"]}]},{"@type":"WebPage","@id":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/","url":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/","name":"Drag and Drop in Anlagefelder - Access im Unternehmen","isPartOf":{"@id":"https:\/\/access-im-unternehmen.de\/#website"},"primaryImageOfPage":{"@id":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/#primaryimage"},"image":{"@id":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/#primaryimage"},"thumbnailUrl":"http:\/\/vg07.met.vgwort.de\/na\/08f2414ba96341138f60497e7d1e522a","datePublished":"2020-05-22T19:08:54+00:00","breadcrumb":{"@id":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/#breadcrumb"},"inLanguage":"de","potentialAction":[{"@type":"ReadAction","target":["https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/"]}]},{"@type":"ImageObject","inLanguage":"de","@id":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/#primaryimage","url":"http:\/\/vg07.met.vgwort.de\/na\/08f2414ba96341138f60497e7d1e522a","contentUrl":"http:\/\/vg07.met.vgwort.de\/na\/08f2414ba96341138f60497e7d1e522a"},{"@type":"BreadcrumbList","@id":"https:\/\/access-im-unternehmen.de\/Drag_and_Drop_in_Anlagefelder\/#breadcrumb","itemListElement":[{"@type":"ListItem","position":1,"name":"Home","item":"https:\/\/access-im-unternehmen.de\/"},{"@type":"ListItem","position":2,"name":"Drag and Drop in Anlagefelder"}]},{"@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\/55001012","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=55001012"}],"version-history":[{"count":0,"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/posts\/55001012\/revisions"}],"wp:attachment":[{"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/media?parent=55001012"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/categories?post=55001012"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/access-im-unternehmen.de\/data\/wp\/v2\/tags?post=55001012"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}