AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Code-Bibliothek Library: Datenbanken Datenbanken-Tipp: Lücken in IDs finden
Thema durchsuchen
Ansicht
Themen-Optionen

Datenbanken-Tipp: Lücken in IDs finden

Ein Thema von Jürgen Thomas · begonnen am 4. Feb 2007 · letzter Beitrag vom 4. Feb 2007
Antwort Antwort
Jürgen Thomas

Registriert seit: 13. Jul 2006
Ort: Berlin
750 Beiträge
 
#1

Datenbanken-Tipp: Lücken in IDs finden

  Alt 4. Feb 2007, 12:34
Mit der folgenden Abfrage werden in einer ID-Spalte einer DB-Tabelle vorhandene Lücken festgestellt:
SQL-Code:
SELECT (Id+1) AS FreieId FROM Tabelle
 WHERE (Id+1) NOT IN (SELECT Id FROM Tabelle)
 ORDER BY FreieId
Wenn nur die kleinste freie ID gesucht wird, kann dieser Befehl ergänzt werden:
SQL-Code:
// MySQL
... LIMIT 1
// Firebird ab 1.5
SELECT FIRST 1 ...
// MSSQL
SELECT TOP 1 ...
Achtung: Stimmt die Variante für MSSQL wirklich? Ich arbeite nicht damit, habe es aber irgendwo aus den Tiefen meines Gedächtnisses so geholt.

Dieser Tipp ist entstanden aus der Diskussion [mysql] Autoinc fehlende Einträge von gsh. Meinen Vorschlag hat gsh geprüft und ergänzt.

Jürgen
#D mit C# für NET, dazu Firebird
früher: Delphi 5 Pro, Delphi 2005 Pro mit C# (also NET 1.1)
Bitte nicht sauer sein, wenn ich mich bei Delphi-Schreibweisen verhaue; ich bin inzwischen an C# gewöhnt.
  Mit Zitat antworten Zitat
Benutzerbild von Jelly
Jelly

Registriert seit: 11. Apr 2003
Ort: Moestroff (Luxemburg)
3.741 Beiträge
 
Delphi 2007 Professional
 
#2

Re: Datenbanken-Tipp: Lücken in IDs finden

  Alt 4. Feb 2007, 12:43
Ergänzend hier mal die Syntax für 3 unterschiedliche DBMS:

MySQL (ab Version 4.1)
SQL-Code:
SELECT (Id+1) AS FreieId FROM Tabelle
WHERE (Id+1) NOT IN (SELECT Id FROM Tabelle)
ORDER BY FreieId
limit 1
Firebird
SQL-Code:
SELECT First 1 (Id+1) AS FreieId FROM Tabelle
WHERE (Id+1) NOT IN (SELECT Id FROM Tabelle)
ORDER BY Id+1
MSSQL
SQL-Code:
SELECT TOP 1 (Id+1) AS FreieId FROM Tabelle
WHERE (Id+1) NOT IN (SELECT Id FROM Tabelle)
ORDER BY Id+1
  Mit Zitat antworten Zitat
Antwort Antwort

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 02:21 Uhr.
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