Heim > Datenbank > MySQL-Tutorial > Wie kann SQL den ersten fehlenden Wert in einer laufenden Zählerspalte identifizieren?

Wie kann SQL den ersten fehlenden Wert in einer laufenden Zählerspalte identifizieren?

Barbara Streisand
Freigeben: 2025-01-13 11:06:41
Original
680 Leute haben es durchsucht

How Can SQL Identify the First Missing Value in a Running Counter Column?

Verwenden Sie SQL, um Lücken in laufenden Zählern zu finden

SQL bietet einen leistungsstarken Mechanismus zum Auffinden fehlender Werte in einer Folge laufender Zähler in einer Tabelle.

Um den ersten fehlenden Wert in der Laufzählerspalte zu ermitteln (z. B. sind die Werte 1, 2, 4 und 5 vorhanden, aber 3 fehlt), können Sie die folgende SQL-Technik verwenden:

MySQL und PostgreSQL:

<code class="language-sql">SELECT id + 1
FROM mytable mo
WHERE NOT EXISTS
(
    SELECT NULL
    FROM mytable mi
    WHERE mi.id = mo.id + 1
)
ORDER BY id
LIMIT 1;</code>
Nach dem Login kopieren

SQL Server:

<code class="language-sql">SELECT TOP 1
id + 1
FROM mytable mo
WHERE NOT EXISTS
(
    SELECT NULL
    FROM mytable mi
    WHERE mi.id = mo.id + 1
)
ORDER BY id;</code>
Nach dem Login kopieren

Orakel:

<code class="language-sql">SELECT *
FROM (
    SELECT id + 1 AS gap
    FROM mytable mo
    WHERE NOT EXISTS
    (
        SELECT NULL
        FROM mytable mi
        WHERE mi.id = mo.id + 1
    )
    ORDER BY id
)
WHERE rownum = 1;</code>
Nach dem Login kopieren

ANSI SQL (am wenigsten effizient):

<code class="language-sql">SELECT MIN(id) + 1
FROM mytable mo
WHERE NOT EXISTS
(
    SELECT NULL
    FROM mytable mi
    WHERE mi.id = mo.id + 1
);</code>
Nach dem Login kopieren

Systeme, die Schiebefensterfunktionen unterstützen:

<code class="language-sql">SELECT previd + 1
FROM (
    SELECT id,
    LAG(id) OVER (ORDER BY id) previd
    FROM mytable
) q
WHERE previd < id
LIMIT 1;</code>
Nach dem Login kopieren

Durch die Verwendung einer dieser SQL-Techniken können Sie fehlende Lücken in Laufzählerspalten in SQL-Tabellen effektiv identifizieren, unabhängig davon, welches Datenbanksystem Sie verwenden.

Das obige ist der detaillierte Inhalt vonWie kann SQL den ersten fehlenden Wert in einer laufenden Zählerspalte identifizieren?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Quelle:php.cn
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Neueste Artikel des Autors
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage