在MySQL表中查找缺失值
如果您有一个增量值表,可能很难找出缺失的值。唯一的解决方案可能是编写脚本以从数据库中获取所有数据,然后查看丢失了哪些数据。但是,有一种无需使用脚本即可执行此操作的方法。
使用这样的标准选择查询:
SELECT*FROMTABLE;
获取以下数据:
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;
该查询给出以下结果。
使用此数据集,我们可以找出数据中的差距所在,也许可以对它们进行一些处理。