Einzelnen Beitrag anzeigen

Furtbichler
(Gast)

n/a Beiträge
 
#6

AW: Tabellengröße auf eine bestimmte Anzahl der Datensätze begrenzen???

  Alt 21. Nov 2012, 18:30
Delete dauert sehr lange, lieber öfter, aber dafür in kleinen Häppchen. Auch bei der Auswahl, welche Daten denn gelöscht werden, würde ich aufpassen.

Wenn man z.B. immer die letzten 5000 löscht (die mit der jeweils kleinsten ID), dann hat man ein Problem, wenn die DB mal keine Daten entgegennimmt (Weihnachten z.B.), dann wird die ja immer kleiner, blöd.

Ich würde das so machen

Code:
create Procedure RemoveOldData
  @MaxRecordsToKeep int,
  @BulkSizeToDelete int
as
declare @currentMax int
select @currentMax = max(ID) from BigTable -- ID is PK and identity
delete from BigTable
 where ID in
   (select top (@BulkSizeToDelete) ID
      from BigTable
     where ID>@currentMax - @MaxRecordsToKeep
 -- order by ID
 -- order by would be more accurate but a bit more time consuming
  )
Das passt einigermaßen, wenn, wie gesagt, ein INSERT meistens funktioniert (also ohne Rollback).

Aufruf dann (Zeitgesteuert, alle 5 minuten z.B. 150k pro Tag, alle 5 minuten löschen = ca. 500 recs alle 5 minuten)
Code:
-- keep 3 Mio recs and delete no more than 1000
RemoveOldData (3000000, 1000)
Mit der Zahl 1000 kann man spielen, um zu prüfen, wie lange das dauert.

Geändert von Furtbichler (21. Nov 2012 um 18:33 Uhr)
  Mit Zitat antworten Zitat