AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Wie schnell viele Datensätze einfügen? [Firebird]
Thema durchsuchen
Ansicht
Themen-Optionen

Wie schnell viele Datensätze einfügen? [Firebird]

Ein Thema von PhilmacFLy · begonnen am 6. Mai 2010 · letzter Beitrag vom 8. Mai 2010
Antwort Antwort
Seite 1 von 3  1 23      
Benutzerbild von PhilmacFLy
PhilmacFLy

Registriert seit: 20. Jan 2008
Ort: Nürnberg
340 Beiträge
 
FreePascal / Lazarus
 
#1

Wie schnell viele Datensätze einfügen? [Firebird]

  Alt 6. Mai 2010, 15:30
Datenbank: Firebird • Version: 2.1.3 • Zugriff über: Zeos
Hey Dp'ler

ich habe folgendes Problem, ich habe hier Messungen die aus 12000 Datensätzen bestehen, für jede Millisekunde einen Datensatz.
Nun hab ich das Problem das ich die alle möglichst schnell in die Firebird DB schreiben muss. Meine Frage ist nun, wie mach ich das am schnellsten und effizientesten?
Philipp N.
"Programmiern ist wie küssen:
Mann kan darüber reden, mann kann es beschreiben,
aber man weiss erst, was es bedeutet,
wenn man es getan hat"
  Mit Zitat antworten Zitat
Benutzerbild von Nersgatt
Nersgatt

Registriert seit: 12. Sep 2008
Ort: Emlichheim
693 Beiträge
 
Delphi 10.1 Berlin Professional
 
#2

Re: Wie schnell viele Datensätze einfügen? [Firebird]

  Alt 6. Mai 2010, 15:39
Willst Du die Daten während der Messung in die DB schreiben?

Am wichtigsten ist, dass man die Insert-Query einmal vorbereitet und Parameter benutzt. So muss die Datenbank das Statement nicht jedes mal neu parsen, sondern nur noch die Parameterwerte setzen und in die Tabelle schreiben. Das spart mächtig viel Zeit.
Außerdem ist es evtl. Zeitsparend, wärend des Schreibens die Trigger und Constraints auszuschalten.

Eine weitere Möglichkeit ist, mehrere Datensätze auf einen Rutsch einzuspeisen. EXECUTE BLOCK ist hier das Stichwort.
Jens
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#3

Re: Wie schnell viele Datensätze einfügen? [Firebird]

  Alt 6. Mai 2010, 15:39
Mit einem parametrisierten Query innerhalb einet Transkation. GGf Index/Trigger temporär deaktivieren
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.202 Beiträge
 
Delphi 10.4 Sydney
 
#4

Re: Wie schnell viele Datensätze einfügen? [Firebird]

  Alt 6. Mai 2010, 15:40
Maximal Geschwindigkeit: Bulk-Insert mit Textdatei
Auch noch sehr gut: Bulk-Insert (Mehrere Insert-Kommandos in eineme Rutsch zur DB schicken) + prepared statement.
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
Benutzerbild von PhilmacFLy
PhilmacFLy

Registriert seit: 20. Jan 2008
Ort: Nürnberg
340 Beiträge
 
FreePascal / Lazarus
 
#5

Re: Wie schnell viele Datensätze einfügen? [Firebird]

  Alt 6. Mai 2010, 15:46
Ok zuerstmal weill ich die daten erst am ende der Messung einspeisen. Ich habs jetzt mal so probiert:

Delphi-Quellcode:
while z <= Ch_Messung.BottomAxis.Maximum do
          begin
            Memo1.Lines.Text := Memo1.Lines.Text + 'INSERT INTO Messwerte (ID_mess, Millisec, Messwert_Links, Messwert_Rechts, Winkel, Merker) VALUES (' + id +',' + InttoStr(z) +','+ Floattostr(ch_messung.Series[0].YValue[z]) + ',' + FloattoStr(ch_messung.Series[1].YValue[z])+', 0, 0);';
            inc(z);
          end;
        SQL.AddStrings(Memo1.Lines);
        ExecSQL;
Geht das noch besser, bzw schneller? Und vor allem wie schnell kann man solche Große datenmengen überhaupt einspeisen?
Philipp N.
"Programmiern ist wie küssen:
Mann kan darüber reden, mann kann es beschreiben,
aber man weiss erst, was es bedeutet,
wenn man es getan hat"
  Mit Zitat antworten Zitat
mkinzler
(Moderator)

Registriert seit: 9. Dez 2005
Ort: Heilbronn
39.861 Beiträge
 
Delphi 11 Alexandria
 
#6

Re: Wie schnell viele Datensätze einfügen? [Firebird]

  Alt 6. Mai 2010, 15:51
3 Leute geben dir einen Ratschlag und du entscheiudest dich für die am garantiert langsamste Variante ( die dir keiner geraten hat!!!!!)
Markus Kinzler
  Mit Zitat antworten Zitat
Benutzerbild von Bernhard Geyer
Bernhard Geyer

Registriert seit: 13. Aug 2002
17.202 Beiträge
 
Delphi 10.4 Sydney
 
#7

Re: Wie schnell viele Datensätze einfügen? [Firebird]

  Alt 6. Mai 2010, 15:51
Zitat von PhilmacFLy:
Geht das noch besser, bzw schneller?
Wurde schon gesagt: Parametrisierte Abfragen/Inserts.

Zitat von PhilmacFLy:
Und vor allem wie schnell kann man solche Große datenmengen überhaupt einspeisen?
Hängt von diversen Faktoren ab.
Ein RAID mit hohen Schreibraten ist mit Sicherheit schneller als eine 0815-USB-Festplatte die evtl. noch an USB 1.1 hängt.
Ein Ausführen auf dem gleichen PC ist schneller als wenn die Daten in Europa von der App abgeschickt werden und in Australien dein Server steht.
Viel RAM hat noch bei keinen DBMS zu einer verschlechterung der Performance geführt.
....
Windows Vista - Eine neue Erfahrung in Fehlern.
  Mit Zitat antworten Zitat
hoika

Registriert seit: 5. Jul 2006
Ort: Magdeburg
8.276 Beiträge
 
Delphi 10.4 Sydney
 
#8

Re: Wie schnell viele Datensätze einfügen? [Firebird]

  Alt 6. Mai 2010, 17:38
Hallo,

Delphi-Quellcode:
while z <= Ch_Messung.BottomAxis.Maximum do
          begin
            Memo1.Lines.Text := Memo1.Lines.Text + 'INSERT INTO Messwerte (ID_mess, Millisec, Messwert_Links, Messwert_Rechts, Winkel, Merker) VALUES (' + id +',' + InttoStr(z) +','+ Floattostr(ch_messung.Series[0].YValue[z]) + ',' + FloattoStr(ch_messung.Series[1].YValue[z])+', 0, 0);';
            inc(z);
          end;
        SQL.AddStrings(Memo1.Lines);
        ExecSQL;
zu Parameter und Prepared Query sage ich nichts mehr ...

Aber:

Jeder Datensatz wird per ExecSQL eingetragen.
Du versuchst ein

Start
Insert Into Satz1
Insert Into Satz2
Insert Into Satz3

ExecSQL


Das geht so nicht.

Ausserdem sind bei dir die beiden letzten GFeldwerte (Winkel,Meker) immer 0 -> als Default-Werte in der DB setzen


Und Transaktionen sehe ich nicht

StartTransaction;
Insert / ExecSQL
Insert / ExecSQL
Insert / ExecSQL
Commit.



Fange erst mal mit den Parametern und Prepared Queries (passt schön zuammen) an.



Heiko
Heiko
  Mit Zitat antworten Zitat
Benutzerbild von Chemiker
Chemiker

Registriert seit: 14. Aug 2005
1.859 Beiträge
 
Delphi 11 Alexandria
 
#9

Re: Wie schnell viele Datensätze einfügen? [Firebird]

  Alt 6. Mai 2010, 18:59
Hallo PhilmacFly,

hat jetzt nicht direkt was mit Deinem Problem zu tun, aber wie bekommst Du denn die Messdaten jede Millisekunde in den PC?

Bis bald Chemiker
wer gesund ist hat 1000 wünsche wer krank ist nur einen.
  Mit Zitat antworten Zitat
Benutzerbild von PhilmacFLy
PhilmacFLy

Registriert seit: 20. Jan 2008
Ort: Nürnberg
340 Beiträge
 
FreePascal / Lazarus
 
#10

Re: Wie schnell viele Datensätze einfügen? [Firebird]

  Alt 6. Mai 2010, 20:52
Timer, iszwar nicht ganz jede Millisekunde, aber fast, da muss ich mir noch was suchen was wirklich jede millisekunde macht
Philipp N.
"Programmiern ist wie küssen:
Mann kan darüber reden, mann kann es beschreiben,
aber man weiss erst, was es bedeutet,
wenn man es getan hat"
  Mit Zitat antworten Zitat
Antwort Antwort
Seite 1 von 3  1 23      


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 17:19 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