在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;
该查询给出以下结果。
使用此数据集,我们可以找出数据中的差距所在,也许可以对它们进行一些处理。
热门推荐
10 对患者生日祝福语简短
11 结婚祝福语简短装备
12 周岁祝福语学生文案简短
13 订婚领证祝福语简短精辟
14 导师获奖祝福语大全简短
15 新婚购房祝福语简短精辟
16 牛年祝福语简短的爱人
17 送芒果的祝福语简短
18 送给学长毕业祝福语简短