Delphi-PRAXiS

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Große Tabelle, schnelle Überprüfung??? (https://www.delphipraxis.net/125831-grosse-tabelle-schnelle-ueberpruefung.html)

romber 12. Dez 2008 16:24

Datenbank: MS SQL Server • Version: 2008 • Zugriff über: ADO

Große Tabelle, schnelle Überprüfung???
 
Hallo!

Ich habe eine lokale MS SQL 2008-Tabelle mit über 1,5 Millionen Datensätzen drin. Jede Sekunde kommen ca. 5-25 neue Datensätze hinzu. Jeden Datensatz verfügt über eine einfeutige ID, die schon vor dem Hinzufügen in die Datenbank bekannt ist. Bei den neuen Daten handelt es sich oft um die bereits vorhandenen Datensätze, die irgendwie geändert wurden. Bis jetzt habe ich die geänderten Daten einfach ignoriert, es werden nur die neue Daten hinzufügt. Dafür sorgt ein Unique-Index, den ich auf die ID-Spalte gesetzt habe.

Jetzt muss ich alles anders machen. Ich muss jede neue Datensatz überprüfen, ob es bereits vorhanden ist und wenn ja - aktualisieren. Meine Aufgabe ist, diese Überprüfung so schnell wie möglich zu machen. Die Überprüfung mit Locate würde bei so vielen Datensätzen mehrere Sekunden in Anspruch nehmen.

Welche Möglichkeiten gibt es? Was könnt Ihr mir empfehlen?

mkinzler 12. Dez 2008 16:26

Re: Große Tabelle, schnelle Überprüfung???
 
MSSQL sollte MERGE unterstützen

Bernhard Geyer 12. Dez 2008 16:42

Re: Große Tabelle, schnelle Überprüfung???
 
Zwei prepared Statements

SQL-Code:
SELECT COUNT(*) FROM <Tabelle> where Key = ?
INSERT INTO(<COls<) VALUES(?,?)
(Evtl bei ADOExpress statt ? entsprechend benahmte Parameter)


Und schon sind 5-25 Inserts in einer Sekudne ein Kinderspiel.


Alle Zeitangaben in WEZ +1. Es ist jetzt 20:33 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-2025 by Thomas Breitkreuz