首页 >数据库 >mysql教程 >如何查找 MySQL 表中缺失的 ID?

如何查找 MySQL 表中缺失的 ID?

Susan Sarandon
Susan Sarandon原创
2024-12-06 02:06:11642浏览

How Can I Find Missing IDs in a MySQL Table?

识别 MySQL 表中缺失的标识符

在 MySQL 表中,可能会遇到缺失的标识符,从而在数字序列中产生间隙。要检索这些缺失的 ID,需要执行特定查询。

查询缺失的 ID

考虑提供的示例表:

ID Name
1 Bob
4 Adam
6 Someguy

来自在此表中,很明显 ID 2、3 和 5 丢失了。要提取这些缺失的标识符,可以使用以下查询:

SELECT a.id+1 AS start, MIN(b.id) - 1 AS end
FROM testtable AS a, testtable AS b
WHERE a.id < b.id
GROUP BY a.id
HAVING start < MIN(b.id);

解释

  • 测试表是自连接的以比较相邻行。
  • id 1(开始)表示紧随当前 ID 之后的潜在缺失 ID (a.id).
  • MIN(b.id) - 1(结束)表示大于起始值的最小 ID 与 1 之间的差值,表示缺失 ID 范围的潜在结束位置。
  • 满足条件的行开始

其他资源

有关此主题的更多信息,请参阅以下内容:

  • [序列间隙示例代码](https://web.archive.org/web/20220706195255/http://www.codediesel.com/mysql/sequence-gaps-in-mysql/)

以上是如何查找 MySQL 表中缺失的 ID?的详细内容。更多信息请关注PHP中文网其他相关文章!

声明:
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn