首頁 > 資料庫 > mysql教程 > 如何找到 My SQL 資料庫表中遺失的自增 ID?

如何找到 My SQL 資料庫表中遺失的自增 ID?

Susan Sarandon
發布: 2025-01-11 09:38:40
原創
158 人瀏覽過

How Can I Find Missing Auto-Incrementing IDs in My SQL Database Table?

使用 SQL 找出表中缺少的 ID

在具有自動遞增主鍵的資料庫表中,已刪除的條目會在欄位值中建立「空洞」。要辨識這些缺少的 ID,可以編寫一個查詢。

MySQL 與 SQL Server 查詢:

<code class="language-sql">SELECT ID + 1
FROM table_name
WHERE ID + 1 NOT IN (SELECT DISTINCT ID FROM table_name);</code>
登入後複製

此查詢將提供表中第一個和最後一個條目之間所有連續缺失 ID 的清單。

SQLite 查詢:

<code class="language-sql">SELECT DISTINCT id +1
FROM table_name
WHERE id + 1 NOT IN (SELECT DISTINCT id FROM table_name);</code>
登入後複製

SQLite 不支援 LIMIT 關鍵字,因此使用 distinct 子查詢來避免重複結果。

其他注意事項:

  • 此查詢假設第一個 ID 為 1。
  • 此查詢不包括任何高於目前最大 ID 的已刪除 ID。
  • 若要包含目前最大值與指定的 MaxID 參數之間的已刪除 ID,請修改查詢如下:
<code class="language-sql">SELECT ID + 1
FROM table_name
WHERE ID + 1 NOT IN (
  SELECT DISTINCT ID FROM table_name
)
AND ID + 1 < MaxID;</code>
登入後複製

請注意,此修改可能並非所有版本的 SQLite 都支援。

以上是如何找到 My SQL 資料庫表中遺失的自增 ID?的詳細內容。更多資訊請關注PHP中文網其他相關文章!

來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板