Delphi-PRAXiS
Seite 1 von 3  1 23      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Wie schnell viele Datensätze einfügen? [Firebird] (https://www.delphipraxis.net/151123-wie-schnell-viele-datensaetze-einfuegen-%5Bfirebird%5D.html)

PhilmacFLy 6. Mai 2010 14:30

Datenbank: Firebird • Version: 2.1.3 • Zugriff über: Zeos

Wie schnell viele Datensätze einfügen? [Firebird]
 
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?

Nersgatt 6. Mai 2010 14:39

Re: Wie schnell viele Datensätze einfügen? [Firebird]
 
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.

mkinzler 6. Mai 2010 14:39

Re: Wie schnell viele Datensätze einfügen? [Firebird]
 
Mit einem parametrisierten Query innerhalb einet Transkation. GGf Index/Trigger temporär deaktivieren

Bernhard Geyer 6. Mai 2010 14:40

Re: Wie schnell viele Datensätze einfügen? [Firebird]
 
Maximal Geschwindigkeit: Bulk-Insert mit Textdatei
Auch noch sehr gut: Bulk-Insert (Mehrere Insert-Kommandos in eineme Rutsch zur DB schicken) + prepared statement.

PhilmacFLy 6. Mai 2010 14:46

Re: Wie schnell viele Datensätze einfügen? [Firebird]
 
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?

mkinzler 6. Mai 2010 14:51

Re: Wie schnell viele Datensätze einfügen? [Firebird]
 
3 Leute geben dir einen Ratschlag und du entscheiudest dich für die am garantiert langsamste Variante ( die dir keiner geraten hat!!!!!)

Bernhard Geyer 6. Mai 2010 14:51

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

Zitat von PhilmacFLy
Geht das noch besser, bzw schneller?

Wurde schon gesagt: Parametrisierte Abfragen/Inserts.

Zitat:

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.
....

hoika 6. Mai 2010 16:38

Re: Wie schnell viele Datensätze einfügen? [Firebird]
 
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

Chemiker 6. Mai 2010 17:59

Re: Wie schnell viele Datensätze einfügen? [Firebird]
 
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

PhilmacFLy 6. Mai 2010 19:52

Re: Wie schnell viele Datensätze einfügen? [Firebird]
 
Timer, iszwar nicht ganz jede Millisekunde, aber fast, da muss ich mir noch was suchen was wirklich jede millisekunde macht


Alle Zeitangaben in WEZ +1. Es ist jetzt 21:17 Uhr.
Seite 1 von 3  1 23      

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