使用null,not in翻车了(oracle)

水平有限,如有错误,请多指正

由于对null和not in理解得不是很透彻,导致在生产环境出问题了,请看下面的sql(为了简单,sql做过调整)

select sd_prestpword,pres.* from ci_pres pres
where pres.sd_prestpword not in('03','04') --非儿科处方

 

我以前的理解是,只要是pres.sd_prestpword不在('03','04')中的记录都会查询出来,包括当pres.sd_prestpword为null的情况,实际情况却不是这样的,会去掉pres.sd_prestpword为null的记录

通过查阅资料发现,null与任何值做比较,返回的都是Unkonwn,而pres.sd_prestpword not in('03','04')相等于pres.sd_prestpword!='03',  pres.sd_prestpword!='04'

而当pres.sd_prestpword为null时,pres.sd_prestpword!='03',  pres.sd_prestpword!='04'返回的是Unkonwn,所以就会把pres.sd_prestpword为null的记录都不会被查询出来

想要为null的记录都查询出来,可以这样修改

select sd_prestpword,pres.* from ci_pres pres
where nvl(pres.sd_prestpword,'-9999') not in('03','04') --非儿科处方

 

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

zxy2847225301

测试使用

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值