Delphi-PRAXiS
Seite 2 von 2     12   

Delphi-PRAXiS (https://www.delphipraxis.net/forum.php)
-   Datenbanken (https://www.delphipraxis.net/15-datenbanken/)
-   -   Delphi Datensätze löschen, dass die 100 neuesten übrig bleiben (https://www.delphipraxis.net/198147-datensaetze-loeschen-dass-die-100-neuesten-uebrig-bleiben.html)

Uwe Raabe 8. Okt 2018 09:43

AW: Datensätze löschen, dass die 100 neuesten übrig bleiben
 
Wenn das ID-Feld tatsächlich ein Zähler ist und keine Lücken in der Tabelle vorkommen können, dann kann man den niedrigsten zu behaltenden ID (MinID) auch über MAX(ID) - 99 errechnen und auf diesem Wert das WHERE für den DELETE Befehl aufbauen.

Falls die obige Bedingung nicht zutrifft, würde ich den MinID über den bereits gezeigten SELECT LIMIT Befehl ermitteln. Ein DELETE ... WHERE ID < MinID ist vermutlich immer noch performanter als ein WHERE ID in (...)

Hobbycoder 8. Okt 2018 09:56

AW: Datensätze löschen, dass die 100 neuesten übrig bleiben
 
Zitat:

Zitat von Uwe Raabe (Beitrag 1415189)
Wenn das ID-Feld tatsächlich ein Zähler ist und keine Lücken in der Tabelle vorkommen können, dann kann man den niedrigsten zu behaltenden ID (MinID) auch über MAX(ID) - 99 errechnen und auf diesem Wert das WHERE für den DELETE Befehl aufbauen.

Falls die obige Bedingung nicht zutrifft, würde ich den MinID über den bereits gezeigten SELECT LIMIT Befehl ermitteln. Ein DELETE ... WHERE ID < MinID ist vermutlich immer noch performanter als ein WHERE ID in (...)

Danke, die Lösung funktioniert ;-)

Jumpy 8. Okt 2018 10:04

AW: Datensätze löschen, dass die 100 neuesten übrig bleiben
 
Mal ein Versuch ohne Top/Limit 100, weiß nicht ob das so ganz passt:

SQL-Code:
Delete From Table
Where ID in
(
Select T.ID From Table T
Group By T.ID
Having (Select count(Distinct ID) From Table Where ID>T.ID)>=100
)

himitsu 8. Okt 2018 10:17

AW: Datensätze löschen, dass die 100 neuesten übrig bleiben
 
Warum umständlich mit Minus und Co. rumjoinen?

MySQL kennt zum LIMIT auch ein OFFSET.



Gut, beim DELETE nicht, aber beim SELECT, also
SQL-Code:
DELETE FROM table WHERE id IN (SELECT id FROM table ORDER BY id OFFSET 100)
.


Zitat:

SQL-Code:
Distinct ID

Wenn ID nicht per se schon einzigartig ist, dann läuft da gewaltig was schief. :stupid:

DeddyH 8. Okt 2018 10:20

AW: Datensätze löschen, dass die 100 neuesten übrig bleiben
 
Dann musst Du aber auch absteigend sortieren.

Hobbycoder 8. Okt 2018 10:46

AW: Datensätze löschen, dass die 100 neuesten übrig bleiben
 
Zitat:

Zitat von himitsu (Beitrag 1415193)
Gut, beim DELETE nicht, aber beim SELECT, also
SQL-Code:
DELETE FROM table WHERE id IN (SELECT id FROM table ORDER BY id OFFSET 100)
.

Aber laut MySQL-Doku (ich hab's aber nicht ausprobiert) bedarf OFFSET den Parameter LIMIT (Kann mich aber auch irren) , und der wird in Subselect nicht supportet.

DasWolf 8. Okt 2018 12:19

AW: Datensätze löschen, dass die 100 neuesten übrig bleiben
 
Ich mache das nach jedem Ermitteln einer neuen ID immer wie folgt:

Delphi-Quellcode:
function TGetMaxID.GetMaxID: integer;
begin
  with TFDQuery.Create(nil) do
  try
    Connection := fConnection;
    sql.add('SELECT IdentityCol');
    sql.add('FROM MaxTable');
    sql.add('WHERE UPPER(rowguid) = :rowguid');
    Params[0].Value := AnsiUpperCase(fRowGuid);
    Prepare;
    open;

    Result := Fields[0].asInteger;

    // Bis auf die letzten 10 Einträge alle Daten aus ID-Tabelle löschen
    sql.clear;
    sql.add('DELETE FROM MaxTable WHERE ID_Max+10 <= :ID_Max');
    Params[0].DataType := ftInteger;
    Params[0].Value := Result;
    Prepare;
    ExecSQL;
  finally
    Free;
  end;
end;


Alle Zeitangaben in WEZ +1. Es ist jetzt 02:11 Uhr.
Seite 2 von 2     12   

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