![]() |
Datenbank: Access • Version: 2000 • Zugriff über: ADO
Per ADO Dateien in Access importieren
Hallo, ich hab da mal ein paar Fragen....
Und zwar bin ich gerade dabei ein Prog zu schreiben was CSV Dateien in eine leere MDB importiert. Mein Problem ist das ich keine CSV's importiert bekomme :D Habe mal gegoogelt und folgendes SQL-Statement für ASP mit ADO gefunden:
SQL-Code:
also hab ich es für Delphi umgeschrieben:
strSQL = "INSERT INTO " & strTableName & " SELECT * FROM [" & strCSVFileName
strSQL = strSQL & "] IN """ & strCSVPath & """ ""TEXT;"""
Delphi-Quellcode:
aber es funktioniert nicht.ADOQuery1.SQL.Add('INSERT INTO TableTest SELECT * FROM [test.csv] IN "C:\test\" "TEXT;"'); er schreibt folgende Fehlermeldung: Oberator muss eine aktualisierbare Abfrage verwenden. Ich versteh nur noch Bahnhof. Was ist falsch an dem SQL Statement, weil eigentlich müsste er doch in der MDB dann eine neue Tabelle mit dem Namen TableTest anlegen und dort die Daten der test.csv die sich in C:\test\ befindet importieren oder nicht? Gibt es eine andere Möglichkeit schnell csv Dateien zu importieren? Hier nochmal der ganze Code:
Delphi-Quellcode:
Und hier mal der Connectionstring der ADOConnection1:
procedure TForm1.Button2Click(Sender: TObject);
var table_vorhanden: boolean; var i: integer; begin ADOConnection1.Connected := True; ADOQuery1.Close; ADOQuery1.SQL.Clear; ADOQuery1.SQL.Add('INSERT INTO TableTest SELECT * FROM [test.csv] IN "C:\test\" "TEXT;"'); ADOQuery1.Open; end; end.
Delphi-Quellcode:
Hoffe ihr habt genug Infos mir zu helfen.
Provider=Microsoft.Jet.OLEDB.4.0;User ID=Admin;Data Source=C:\RTS-Auswertungstool\RTS-Auswertungstool.mdb;Mode=Read;Extended Properties="";Jet OLEDB:System database="";Jet OLEDB:Registry Path="";Jet OLEDB:Database Password="";Jet OLEDB:Engine Type=5;Jet OLEDB:Database Locking Mode=0;Jet OLEDB:Global Partial Bulk Ops=2;Jet OLEDB:Global Bulk Transactions=1;Jet OLEDB:New Database Password="";Jet OLEDB:Create System Database=False;Jet OLEDB:Encrypt Database=False;Jet OLEDB:Don't Copy Locale on Compact=False;Jet OLEDB:Compact Without Replica Repair=False;Jet OLEDB:SFP=False
MFG Andre PS: Danke schonmal für die Hilfe |
Re: Per ADO Dateien in Access importieren
Hi
Zitat:
|
Re: Per ADO Dateien in Access importieren
Das ist alles?? warum kann Delphi mir nicht das als Fehlermeldung sagen ^^
EH Alter erst Tabelle anlegen dann gehts!!! :D ja so dann hab ich mal ne folge Frage, gibt es denn irgendeinen befehl der Schaut welche Struktur die csv Datei hat und der dann die Tabelle anlegt?? oder darf ich jetzt schön nen SQL-Statement schreiben welches dann mit create table das anlegt?? weil es ganz schön viele sind ^^ Danke für deine Hilfe Ach so :dp: |
Re: Per ADO Dateien in Access importieren
Hallo, Tomate,
Wenn INSERT, dann muss die Tabelle bereits existieren, da Du ja einfügst. Wenn die Tabelle neu angelegt werden soll, muss es SELECT INTO heißen. Dann darf sie aber auch nicht existieren. Zu Deiner Frage: Woran soll man in einer csv-Datei die Struktur kennen? Da steht doch nur Text. Wie also kann man ein Textfeld von einem Datumsfeld oder einem Zahlenfeld unterscheiden. Du kannst allerdings, falls in der ersten Zeile die Feldnamen stehen, Dir ein kleines Tool schreiben, das die Feldnamen einliest - meinetwegen in ein Grid. Dann wählst Du nacheinander die Feldnamen aus und klickst dir aus einer Radiogroup den entsprechenden Typ dazu. Die Generierung der SQL überlässt Du dann dem Programm. Joffm |
Alle Zeitangaben in WEZ +1. Es ist jetzt 04:49 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz