水平有限,如有错误,请多指正
由于对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') --非儿科处方