好久没有更了,可能是因为这些个时间也没有学习吧。诶,学不动了学不动了。学得又慢,自己注意力也容易分散。瞅瞅自己的状态,极大概率要菜一辈子了。(这都是废话。)
下面说正题。今天遇到一个问题,让我想把自己之前上线过的所有增删改查都重写一遍。这个问题就是not in失效的问题。
昨天在我接手的系统有个问题,业务说自己之前能看到的数据看不见了(本人工作性质:开发、运维、对接业务基本上都做。)。毕竟不是自己写的代码,以为自己是修改了某个bug触发一系列别的bugs(如下图)。
下面上原sql语句
SELECT *
FROM BIAOA a
WHERE 1 = 1
AND a.id NOT IN (SELECT a_id FROM BIAOB)
AND status = 16
这有什么问题?没错,这什么问题都没有!!!那么问题来了,既然什么问题都没有,为什么会出问题?
出问题的原因是:由于select a_id from BIAOB里查到到a_id为null的记录,导致not in失效。
解决方法:直接删除BIAOB里面a_id为null的数据喽~~
当然还有其它解决方法,优化sql语句或者用not exists等等一大堆,这就见仁见智了。总之看到not in 失效,一定要看下有没有null的记录。