Delphi-PRAXiS
Seite 1 von 2  1 2      

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Etwas komlizierte DELETE-Statement??? (https://www.delphipraxis.net/148917-etwas-komlizierte-delete-statement.html)

romber 10. Mär 2010 23:16

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

Etwas komlizierte DELETE-Statement???
 
Hallo!

Ich bekomme über einen Webservice viele Datensätze und füge diese einer Tabelle hinzu. Meistens sind das neue Datensätze, doch manchmal kommen auch die Datensätze, die bereits in der Tabelle vorhanden sind und geändert wurden. Diese füge ich ebenfalls hinzu, um später die Änderungen nachvollziehen zu können. In die Spalte "ic_datetime" schreibe ich immer die aktuelle Datum rein.

Nun möchte ich dem SQL Server Agent einen Auftrag verpassen, alle Datensätze und deren geänderte Kopien zu löschen, wenn letzte Änderung mehr als 3 Monate zurückliegt. Ich komme irgendwie mit dem SQL-Befehl nicht klar. Bitte um Hilfe!

omata 10. Mär 2010 23:42

Re: Etwas komlizierte DELETE-Statement???
 
Das sind ja unglaublich hilfreiche Informationen, die du uns da so hinschmeißt.

SQL-Code:
DELETE FROM tabelle
FROM tabelle x
WHERE NOT EXISTS (SELECT *
                  FROM tabelle
                  WHERE id = x.id
                    AND ic_datetime > DATEADD(m, -3, GETDATE()))

romber 11. Mär 2010 00:27

Re: Etwas komlizierte DELETE-Statement???
 
Vielen Dank!

romber 12. Mär 2010 14:01

Re: Etwas komlizierte DELETE-Statement???
 
Klappt irgendwie nicht.

SQL-Code:
DELETE
FROM ldf_objects x
WHERE NOT EXISTS (SELECT * 
                  FROM ldf_objects
                  WHERE id = x.id
                  AND ic_datetime > DATEADD(m, -3, GETDATE()))
Ich bekomme die Fehlermeldung Falsche Syntax in der Nähe von 'X'.

Sharky 12. Mär 2010 14:06

Re: Etwas komlizierte DELETE-Statement???
 
Ich denke mal das Omata das x nur als Platzhalter für den Tabellennamen geschrieben hat. ;-)

romber 12. Mär 2010 14:29

Re: Etwas komlizierte DELETE-Statement???
 
Zitat:

Zitat von Sharky
Ich denke mal das Omata das x nur als Platzhalter für den Tabellennamen geschrieben hat. ;-)

Denke ich nicht. Denn es wird auch in der zweiten SELECT-Abfrage benutzt. Denn so

SQL-Code:
DELETE
FROM ldf_objects
WHERE NOT EXISTS (SELECT * 
                  FROM ldf_objects
                  WHERE id = ldf_objects.id
                  AND ic_datetime > DATEADD(m, -3, GETDATE()))
passiert gar nicht und ergibt eigentlich keinen Sinn. Wenn ich Omata's Code statt DELETE mit SELECT verwende, werden die betroffene Datensätze angezeigt.

SQL-Code:
SELECT *
FROM ldf_objects x
WHERE NOT EXISTS (SELECT * 
                  FROM ldf_objects
                  WHERE id = x.id
                  AND ic_datetime > DATEADD(m, -3, GETDATE()))
Mit DELETE habe ich o.g. Fehler.

p80286 12. Mär 2010 14:59

Re: Etwas komlizierte DELETE-Statement???
 
Hallo Romber,

Es soll ja SQL-Server Versionen gegeben haben die nur so etwas konnten:
SQL-Code:
DELETE FROM Tabelle WHERE Tabelle.ID=123456
sprich, keine Bezüge zu anderen Tabellen zuließen und auch keine Subselects akzeptierten.

ausserdem halte ich die Abfrage für falsch.
wenn ich Deine Frage richtig verstanden habe liegen die Daten in folgender Form vor:
Code:
ID Dateninhalt ic_datetime
ID sollte für jeden Datensatz unterschiedlich sein, darum
SQL-Code:
DELETE
FROM tabelle x
WHERE NOT EXISTS (SELECT * 
                  FROM Tabelle
                  WHERE dateninhalt = x.dateninhalt
                  AND ic_datetime > DATEADD(m, -3, GETDATE()))
Gruß
K-H

romber 12. Mär 2010 16:33

Re: Etwas komlizierte DELETE-Statement???
 
Zitat:

Zitat von p80286
ID sollte für jeden Datensatz unterschiedlich sein, darum

ID ist eben nicht immer unterschiedlich. Wenn ein geändertes Datensatz hinzu gefügt wird, dann sind auch die IDs gleich. Ich habe in der Tabelle noch eine Spalte, die automatisch hochgezählt wird. Das ist aber nicht wichtig.

p80286 12. Mär 2010 16:50

Re: Etwas komlizierte DELETE-Statement???
 
Wie Du die Felder in Deiner DB benennst, ist natürlich alleine Deine Sache.
Nach meinem Verständnist ist ID der eindeutige Satzschlüssel, der dementsprechend auch nicht mehrfach vorkommen kann.

Gruß
K-H

romber 12. Mär 2010 17:12

Re: Etwas komlizierte DELETE-Statement???
 
Zitat:

Zitat von p80286
Nach meinem Verständnist ist ID der eindeutige Satzschlüssel, der dementsprechend auch nicht mehrfach vorkommen kann.

Nach meinem auch. Es heißt auch anders bei mir. Omata hat in seinem Beispiel ID verwendet.

Spalte id in meiner Tabelle ist eindeutiger Satzschlüssel und wird automatisch hochgezählt. In die Spalte ic_id wird die ID-Nummer des Datensatzen hinzufügt, praktisch die IDdes Datensatzes in der Tabelle des Datenlieferanten. Und die kann gleich sein, wenn geänderte Datem hinzufügen werden.


Alle Zeitangaben in WEZ +1. Es ist jetzt 00:44 Uhr.
Seite 1 von 2  1 2      

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