在MySQL表中查找缺失值

如果您有一个增量值表,可能很难找出缺失的值。唯一的解决方案可能是编写脚本以从数据库中获取所有数据,然后查看丢失了哪些数据。但是,有一种无需使用脚本即可执行此操作的方法。

使用这样的标准选择查询:

SELECT * FROM TABLE;

获取以下数据:

1
3
10
23

我们可以看到缺少值,但是哪个值呢?以下查询将向我们显示表格数据中的差距。

SELECT t1.id+1 AS Missing
FROM TABLE AS t1
LEFT JOIN TABLE  AS t2 ON t1.id+1 = t2.id
WHEREt2.idIS NULL
ORDER BY t1.id;

产生以下结果。

2
4
11
24

但是,这仅告诉我们差距在哪里,而不是差距有多久。为了获得差距的来回范围,我们需要做一些更复杂的事情。

SELECT
t1.id+1 AS 'Missing From',
MIN(t2.id) - 1 AS 'To'
FROM TABLE AS t1, TABLE AS t2
WHERE t1.id < t2.id
GROUP BY t1.id
HAVING t1.id < MIN(t2.id) - 1;

该查询给出以下结果。

缺少
22个
49
1122

使用此数据集,我们可以找出数据中的差距所在,也许可以对它们进行一些处理。