Einzelnen Beitrag anzeigen

Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#13

Re: Performance Problem bei SQL-Abfrage

  Alt 22. Aug 2006, 13:15
Wenn es nur 10000 Werte in der Textdatei sind, würd ich den ganzen Bestand erstmal einfach in eine Stringlist laden, oder in eine vielleicht besser geeignete Speicherstruktur, wie auch immer.

Dann wie folgt vorgehen:
Alle IDs (nenn ich jetzt mal die Spalten über die Du testen willst, ob der Record schon in der MySQL Tabelle existiert) suchen, die bereits in der DB vorhanden sind. Dazu baust du dir ein kommaseparated String zusammen, über alle Datensätze im Speicher. Das wird dann sowas:
1,2,3,4,5,...,10000
und führst anschliessend ein select aus, in dem du bestehende Datensätze suchst:
select id from deinetable where ID in (1,2,3,4,4,...,10000) Jetzt durchläufst du deine Stringlist:
ist ID bereits vorhanden -> update Statement für den Record formulieren und zum Server schicken. Updates musst Du leider einzeln abarbeiten.
ist ID noch nicht in der Tabelle drin, dann den Values Tupel, als kommasarated bilden:
(1,'blu'),(2,'bla')...
also neue Datensätze einfach hin anhängen.

Zum Schluss noch ein letztes Insert in die Tabelle:
insert into deinetable (ID,Spalte2) values (1,'blu'),(2,'bla')... Das ist imho die schnellste Möglichkeit, neben dem direkten Laden über den Load Befehl von MySQL, falls es denn damit geht.
  Mit Zitat antworten Zitat