Delphi-PRAXiS
Seite 2 von 3     12 3      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi 10.000 Datensätze ganz schnell einfügen (https://www.delphipraxis.net/25772-10-000-datensaetze-ganz-schnell-einfuegen.html)

Sharky 12. Jul 2004 20:46

Re: 10.000 Datensätze ganz schnell einfügen
 
Zitat:

Zitat von mytar
Ich hab da einfach ein Sanduhr als MouseStyle gesetzt....

Hai mytar,
das ist ja schön und gut. Aber was hat das mir der Frage zu tun?

tuxic 13. Jul 2004 09:25

Re: 10.000 Datensätze ganz schnell einfügen
 
Zitat:

Zitat von Chris1986
Gibst du jeden der 10.000 Schleifendurchläufe optisch aus? Dann ist es klar, dass das länger dauert. :lol: Nimm das mal raus, dann sollte es schon VIEL schneller gehen

rofl - sicher braucht er am ende 5sec länger, aber das macht bei ca. 10min dann auch nix mehr ;)

Daniel

Maa83 13. Jul 2004 10:23

Re: 10.000 Datensätze ganz schnell einfügen
 
nein er braucht nicht nur 5 Sekunden länger sondern um einiges länger...
ich hab das auch mal mit einem Zähler mitlaufen lassen... habs aber schnell wieder rausgenommen weil das ohne Ende Performance frisst!

grayfox 13. Jul 2004 13:18

Re: 10.000 Datensätze ganz schnell einfügen
 
hallo maa!

du kannst ja auch bei deinem zähler festlegen, dass er zb nur bei jeden hundertsten datensatz die anzeige aktualisiert - dann beschäftigt sich das prog wieder mehr mit dem einlesen als mit dem anzeigen.

mfg, stefan

Maa83 13. Jul 2004 13:26

Re: 10.000 Datensätze ganz schnell einfügen
 
I know...

aber ich nehm lieber einen "bitte warten" Bildschirm :)

@tuxic: Wie schreibst du die Datensätze eigentlich weg? Mit ner AdoQuery oder mit selbstgeschriebenen Dingen oder wie? Wie lautet dein SQL-Befehl...
Vielleicht kann man da ja was optimieren...

mfg
Maa

mytar 13. Jul 2004 15:06

Re: 10.000 Datensätze ganz schnell einfügen
 
@Chris1986: Ich denke ControlsEnabled macht das ja.

woki 13. Jul 2004 15:34

Re: 10.000 Datensätze ganz schnell einfügen
 
Zitat:

Zitat von mytar
@Chris1986: Ich denke ControlsEnabled macht das ja.

nein, dies aktiviert (deaktiviert) nur das visuelle updaten der von diesem Dataset abhängenden datensensitiven Controls, alle anderen Möglichkeiten zur Ausgabe sind davon nicht betroffen. Wenn ich also nach jedem Datensatz das Interface update (eine Info schreiben), dann frißt das mehr Zeit als alles andere, bezogen auf die meisten Probleme,die auf PC-Systemen bearbeitet werden.

Grüße
Woki

tuxic 13. Jul 2004 15:50

Re: 10.000 Datensätze ganz schnell einfügen
 
Zitat:

Zitat von Maa83
@tuxic: Wie schreibst du die Datensätze eigentlich weg? Mit ner AdoQuery oder mit selbstgeschriebenen Dingen oder wie? Wie lautet dein SQL-Befehl...
Vielleicht kann man da ja was optimieren...

UI, also ich schiebe erst einen Datensatz in ein Array einer Klasse, um dann zusagen Klasse.save2db (mal bildlich gesprochen :) ) .
Das einfügen passiert mit einem einfachen
SQL-Code:
INSERT INTO table (fields) VALUES (data)
Daniel

Maa83 13. Jul 2004 16:09

Re: 10.000 Datensätze ganz schnell einfügen
 
hast du schonmal versucht dir erst den kompletten insert string zu schreiben und ihn dann nur einmal ausführen?

also so:

Delphi-Quellcode:
for i := 0 to ende do begin
   sqlString := sqlString + ',INSERT INTO '+Tabelle+' VALUES ('+werte+')';
end;
Delete(sqlString,1,1);

adocom_tmp.CommandString := sqlString;
adocom_tmp.Execute;
also quasi die ganzen Inserts mit Komma getrennt auflisten und dann ausführen... müsste auch um einiges schneller gehen...

wenn du dann noch die grafische ausgabe komplett unterbindest müsste das unterhalb einer Minute durchlaufen!

(obiger Code nicht getestet... das heisst es könnten sich kleine Fehler eingeschlichen haben!)

Robert_G 13. Jul 2004 16:32

Re: 10.000 Datensätze ganz schnell einfügen
 
Zitat:

(obiger Code nicht getestet... das heisst es könnten sich kleine Fehler eingeschlichen haben!)
Jupp, er ist falsch!

Seit wann kannst du in SQL, kommagetrennt, Statements absetzen :?:

Nachdem ich diesen Thread etwas verfolgt habe, frage ich mich: Benutzt ihr INSERT/EDIT/Post des DataSet????

sowas hier...
Delphi-Quellcode:
...
  SomeTDataSetDescendant.Insert;
  //do something
  SomeTDataSetDescendant.Post;
... hat ABSOLUT nichts mit performantem Datenzugriff gemeinsam!

Nachdem es auch schon der Paradox-erfahrene Vulkanier gesagt hat, plädiere ich immer noch auf BatchMove!


Alle Zeitangaben in WEZ +1. Es ist jetzt 08:18 Uhr.
Seite 2 von 3     12 3      

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