![]() |
Datenbank: FireDAC • Version: 10 • Zugriff über: FireDAC
FireDAC kopieren mit Query1.Data := Query2.Data
Hallo.
Ich habe zwei Datenbanken zwischen denen ganze Tabellen kopiert werden müssen. Die DBs können unterschiedliche Formate (Access, SQLite, Firebird, MS SQL) haben, werden aber immer über FireDAC geöffnet. Bisher wurde die Quelltabelle durchlaufen und Record für Record kopiert. Zu langsam bei sehr großen Datasets. Es bieten sich mehrere Möglichkeiten: TFDQuery.CopyDataSet, TFDBatchMove und die wohl schnellste Methode mit TFDDataset.Data. Nutzt das jemand?
Code:
Da passiert rein garnichts. Habe zum Test auch für beide Query eine Access-DB genommen. In der Ziel-DB ist eine Tabelle mit gleichen Datenfeldern vorhanden.
FDQuerySrc.Open('SELECT * FROM document');
FDQuerySrc.FetchAll; FDQueryDst.SQL.Assign(FDQuerySrc.SQL); FDQueryDst.Data := FDQuerySrc.Data; Würde mich über Tipps und Hinweise freuen. Gruß, Harald |
AW: FireDAC kopieren mit Query1.Data := Query2.Data
Zitat:
1, Alles über prepared statements läuft 2, Die Inserts nicht nur ein Datensatz schreiben sondern gleich mehrere (insert into tab1(feld1, feld2, ...) values('1', '2', ...) (...) (...) (genau Syntax weicht hier von DBMS zu DBMS ab. |
AW: FireDAC kopieren mit Query1.Data := Query2.Data
Eine weitere Möglichkeit der Beschleunigung wäre es, den Index abzuschalten.
Nur, warum willst Du eine(?) ganze Tabelle kopieren? Zumindest der PK ist doch wahrscheinlich DB-spezifisch? Wenn es darum geht eine ganze DB zu duplizieren, würde es sich anbieten, ein Skript mit den DDE-Befehlen und den Insert Statements zu erstellen. Gruß K-H |
AW: FireDAC kopieren mit Query1.Data := Query2.Data
Das Data-Property ist für diese Aufgabe nicht geeignet, da es lediglich die Daten in das Ziel-DataSet übernimmt (eigentlich sogar nur als Referenz und nicht als Kopie). Damit landen aber noch keine Daten in irgendeiner Datenbank.
CopyDataSet wird auch nicht wesentlich schneller sein, da es ebenfalls jeden Record einzeln kopiert. Es macht aber halt einen schlanken Code. Ich würde es mal mit TFDBatchMove probieren, da es exakt für diesen Fall gedacht ist. |
AW: FireDAC kopieren mit Query1.Data := Query2.Data
Besten Dank für eure Antworten.
Zitat:
![]() Ich habe mit CopyDataset jetzt aber eine brauchbare Performance. Schneller wäre schön, Zitat:
Gruß, Harald |
AW: FireDAC kopieren mit Query1.Data := Query2.Data
Moin...:P
Zitat:
Zitat:
|
AW: FireDAC kopieren mit Query1.Data := Query2.Data
Zitat:
|
AW: FireDAC kopieren mit Query1.Data := Query2.Data
Welchen Zeitrahmen für die Übertragung der 11 Mio Zeilen stellst du dir vor?
Letztendlich, egal wie du es machst, kommst du nicht drumherum die Statements Richtung Datenbank abzusetzen. Verschiede DBMS unterstützen BULK INSERT. Quasi Import von Massendaten. 8-) Das erfordert aber eine DBMS spezifische Implementierung. |
AW: FireDAC kopieren mit Query1.Data := Query2.Data
Zitat:
Der Knackpunkt liegt in der Zeile darüber: Zitat:
Im Gegensatz zu CopyDataSet: Zitat:
|
Alle Zeitangaben in WEZ +1. Es ist jetzt 17:40 Uhr. |
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz