AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Datenbanken Delphi Tabellengröße auf eine bestimmte Anzahl der Datensätze begrenzen???
Thema durchsuchen
Ansicht
Themen-Optionen

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

Ein Thema von romber · begonnen am 21. Nov 2012 · letzter Beitrag vom 22. Nov 2012
 
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
 


Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 01:14 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