oracle not in语句突然失效解决方法

好久没有更了,可能是因为这些个时间也没有学习吧。诶,学不动了学不动了。学得又慢,自己注意力也容易分散。瞅瞅自己的状态,极大概率要菜一辈子了。(这都是废话。)

下面说正题。今天遇到一个问题,让我想把自己之前上线过的所有增删改查都重写一遍。这个问题就是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的记录。

  • 3
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值