AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi csv Datei in mysql DB einlesen
Thema durchsuchen
Ansicht
Themen-Optionen

csv Datei in mysql DB einlesen

Ein Thema von marcibaer · begonnen am 18. Okt 2012 · letzter Beitrag vom 20. Okt 2012
Antwort Antwort
marcibaer

Registriert seit: 27. Sep 2006
Ort: Inden
74 Beiträge
 
Delphi XE2 Professional
 
#1

csv Datei in mysql DB einlesen

  Alt 18. Okt 2012, 10:59
Datenbank: mysql • Version: 5 • Zugriff über: Delphiprogramm
Hallo zusammen!

Ich versuche mich das 1. Mal mit 'ner mySQL-DB und hab bisher Folgendes erreicht:
ich erzeuge aus meinem Delphi-Programm eine csv-Datei, die ich dann per FTP (aus den Indys) auf die Homepage hochlade. Jetzt habe ich gelesen, dass ich per "LOAD DATA INFILE" die Datei importieren kann. Aber wie funktioniert das aus dem Programm heraus oder muss ich den Befehl in 'ne php-Seite "stecken" oder oder oder ...!?
Das Ganze soll jedenfalls komplett aus dem Programm erledigt werden!

Vielen Dank für Eure Hilfe!
Marc
  Mit Zitat antworten Zitat
Benutzerbild von Gollum
Gollum

Registriert seit: 14. Jan 2003
Ort: Boxberg
456 Beiträge
 
Delphi 10.1 Berlin Professional
 
#2

AW: csv Datei in mysql DB einlesen

  Alt 18. Okt 2012, 11:19
Hallo,

am besten mit einem ADOCommand- oder wenn Du du MyDAC besitzt mit einem TMyCommand-Objekt:

Delphi-Quellcode:
const
  qryImportCSV=
    'LOAD DATA LOCAL INFILE ''%s'' '+
    'INTO TABLE %s '+
    'FIELDS TERMINATED BY '';'' '+
    'IGNORE 1 LINES'; // falls 1. Zeile Spaltenüberschriften enthält


...
var DateiName:String;
...
  DateiName:=StringReplace('X:\EinVerzeichnis\Meinedatei.csv', '\', '/', [rfReplaceAll]);
// MyDAC
  MyCommand.SQL.Text:=Format(qryImportCSV, [DateiName, 'MeineTabelle']);
  MyCommand.Execute();

// oder mit ADO
  MyCommand.CommandText:=Format(qryImportCSV, [DateiName, 'MeineTabelle']);
  MyCommand.Execute();
...
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#3

AW: csv Datei in mysql DB einlesen

  Alt 18. Okt 2012, 13:43
Wenn du direkt aud den MySQL Server zugreifen kannst, dann ist es nicht nötig die csv Datei per FTP oder wie auch immer zum Server zu schieben.
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
marcibaer

Registriert seit: 27. Sep 2006
Ort: Inden
74 Beiträge
 
Delphi XE2 Professional
 
#4

AW: csv Datei in mysql DB einlesen

  Alt 18. Okt 2012, 15:13
@Sir Rufo: die DB liegt auf meiner Homepage.
@Gollum:
Hab das mal so probiert und mir den mySQL ODBC Treiber aus'm Netz besorgt.
Delphi-Quellcode:
const
  qryImportCSV=
    'LOAD DATA LOCAL INFILE ''%s'' '+
    'INTO TABLE %s '+
    'FIELDS TERMINATED BY '';'' '+
    'IGNORE 1 LINES'; // falls 1. Zeile Spaltenüberschriften enthält
  StrConnection='Driver={MySQL ODBC 3.51 Driver};Server=%s;Database=%s;'+
                'User=%s; Password=%s;Option=3;';
var
  Command: TADOCommand;
begin
  DateiName := '/DB-Export.csv';
  Command := TADOCommand.Create(nil);
  with Command do
    try
      with Online^ do
        ConnectionString := Format(StrConnection,[Servername,Datenbank,Username,Passwort]);
      CommandText := Format(qryImportCSV, [DateiName, 'Person']);
      Execute;
    finally
      Free;
    end;
Anscheinend lässt der mich der Server aber nicht rein, da ich die Fehlermeldung "[MySQL][ODBC 3.51 Driver] Can't connect to MySQL server on 'rdbms.strato.de' (10061)" bekomme.

Was muss ich da denn noch zusätzlich festlegen!?
Marc
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#5

AW: csv Datei in mysql DB einlesen

  Alt 18. Okt 2012, 16:50
Also ich würde erstmal eine reine Verbindung ohne SchnickSchnack zum Server herstellen.

Manchmal hilft es auch den Provider zu fragen, wie man denn auf den Server zugreifen kann.
Irgendwie hatte ich aber das Gefühl, dass du die Verbindung zum Server schon hergestellt hattest???

Egal, der Provider kann den Server auf mehrere Arten von der Aussenwelt abschotten - bis zu dem Punkt, dass keiner von aussen ran kommt.
Dann geht alles nur per PHP o.ä.
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
marcibaer

Registriert seit: 27. Sep 2006
Ort: Inden
74 Beiträge
 
Delphi XE2 Professional
 
#6

AW: csv Datei in mysql DB einlesen

  Alt 18. Okt 2012, 17:17
PHP ist 'nen gutes Stichwort!

Wie sähe das denn dann damit aus und könnte ich das trotzdem aus meinem Delphi-Programm steuern!?

Hab erst 'nen bißchen in PHP reingeschnupptert ...
Marc
  Mit Zitat antworten Zitat
Benutzerbild von DeddyH
DeddyH

Registriert seit: 17. Sep 2006
Ort: Barchfeld
27.542 Beiträge
 
Delphi 11 Alexandria
 
#7

AW: csv Datei in mysql DB einlesen

  Alt 19. Okt 2012, 15:05
Gewisse (unkritische) Bereiche unserer Firmen-Website administriere ich auch mit PHP-Scripten, die von einem Delphi-Programm angesprochen werden. Man muss sich dann aber darüber im Klaren sein, dass man diesen Kommunikationsweg irgendwie absichern muss, da ja sonst theoretisch jeder, der den Namen und die erwarteten Parameter der Scripte kennt, mal eben in der DB löschen/eintragen/ändern kann.
Detlef
"Ich habe Angst vor dem Tag, an dem die Technologie unsere menschlichen Interaktionen übertrumpft. Die Welt wird eine Generation von Idioten bekommen." (Albert Einstein)
Dieser Tag ist längst gekommen
  Mit Zitat antworten Zitat
marcibaer

Registriert seit: 27. Sep 2006
Ort: Inden
74 Beiträge
 
Delphi XE2 Professional
 
#8

AW: csv Datei in mysql DB einlesen

  Alt 20. Okt 2012, 08:38
das ist ja meine Frage:
WIE spreche ich denn php Skripte von Delphi aus an?!

Das Skript selber besteht dann wohl aus DB-Aufrufen wie DELETE FROM Person; und anschließendem Einlesen der csv-Datei ind INSERT der einzelnen Zeilen, oder?!
Liest man die Datei dann in einem Rutsch ein und geht dann die Zeilen durch oder lieber direkt zeilenweise einlesen?
Wird das Ganze dann nicht ziemlich langsam, je nachdem wie viele Zeilen/INSERTs es gibt!?
Marc

Geändert von marcibaer (20. Okt 2012 um 08:41 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von Sir Rufo
Sir Rufo

Registriert seit: 5. Jan 2005
Ort: Stadthagen
9.454 Beiträge
 
Delphi 10 Seattle Enterprise
 
#9

AW: csv Datei in mysql DB einlesen

  Alt 20. Okt 2012, 08:52
Ein PHP-Skript liegt auf einem Webserver, also muss ich wohl mit dem Webserver sprechen.
Somit ist es eigentlich egal, was bei dem Webserver im Hintergrund werkelt (kann eben PHP sein), es geht dabei nur um die Funktion.

Bau dir ein PHP Skript dass eine CSV Datei entgegennimmt und in die Datenbank pustet. (eigentlich das falsche Forum)

In Delphi brauchst du dann etwas um diese Funktion des Webservers anzusprechen (dafür gibt es z.B. die INDYs). Wie der konkrete Zugriff auf die Funktion aussehen muss hängt von der Aufrufkonvention der Funktion ab.

Also erstmal die Funktion schaffen und dann den Zugriff darauf.

Das ist wie mit dem Radio, das wurde erst erfunden nachdem man die Sprache entdeckt hatte, vorher hatte man sich einfach nichts zu sagen
Kaum macht man's richtig - schon funktioniert's
Zertifikat: Sir Rufo (Fingerprint: ‎ea 0a 4c 14 0d b6 3a a4 c1 c5 b9 dc 90 9d f0 e9 de 13 da 60)
  Mit Zitat antworten Zitat
Antwort Antwort


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 05:23 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz