Utilisez SQL pour trouver des lacunes dans l'exécution des compteurs
Lorsque vous travaillez avec des tables de données contenant des colonnes de compteurs en cours d'exécution, vous devrez peut-être identifier les valeurs séquentielles manquantes dans ces compteurs. En SQL, cette tâche peut être accomplie efficacement en utilisant une combinaison de théorie des ensembles et de techniques de tri.
Pour déterminer le premier espace dans la colonne du compteur, nous utilisons l'opérateur NOT EXISTS en conjonction avec une sous-requête pour filtrer les lignes avec des valeurs consécutives. Cela garantit que nous isolons les lignes avec des séquences manquantes. Nous isolons ensuite le premier écart découvert en triant les lignes par ordre croissant à l'aide de la clause ORDER BY.
MySQL et 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>
SQL Serveur :
<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>
Oracle :
<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>
ANSI (toutes les bases de données supportées, mais moins performantes) :
<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>
SGBD avec fonction fenêtre coulissante :
<code class="language-sql">SELECT -- TOP 1 -- Uncomment above for SQL Server 2012+ previd + 1 FROM ( SELECT id, LAG(id) OVER (ORDER BY id) previd FROM mytable ) q WHERE previd <> id - 1 ORDER BY id -- LIMIT 1 -- Uncomment above for PostgreSQL</code>
En tirant parti de ces techniques, vous pouvez identifier efficacement les valeurs manquantes dans les colonnes de compteurs séquentiels dans SQL pour effectuer efficacement les tâches d'analyse et de maintenance des données.
Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!