oracle查询语句not in,oracle中的not in慎用

前几天帮朋友看了个奇怪的sql问题:

查找该表中有父节点的的记录,用以下sql:

select MATERIAL_TYPE_ID from MATERIAL_CATEGORY

where MATERIAL_TYPE_ID in

(select distinct PARENT_ID   as MATERIAL_TYPE_ID from MATERIAL_CATEGORY )

正常逻辑,查找该表中无父节点的的记录,就应该用not in:

select MATERIAL_TYPE_ID from MATERIAL_CATEGORY

where MATERIAL_TYPE_ID not in

(select distinct PARENT_ID   as MATERIAL_TYPE_ID from MATERIAL_CATEGORY )

但结果却返回0条记录,这就很奇怪了。

在查了相关资料才想起是null的问题,PARENT_ID必然存在值为null的记录,oracle中和null比较的返回值是unkown,所以才无法匹配。

这里我们可以用not exists来代替not in:

select MATERIAL_TYPE_ID from MATERIAL_CATEGORY MC where not exists

(select 1 from MATERIAL_CATEGORY where PARENT_ID=MC.MATERIAL_TYPE_ID)

这样结果就对了。。。。。

not in (...) 括号中的返回值不能存在null值,是Oracle SQL开发的一条铁律,如果不能确定返回结果一定无null值,还是改写为not esists吧。呵呵,这点偶也忘了。。。

另外not in效率低下,一般不能用到索引,生产环境的程序最好不要使用。

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/14019112/viewspace-620664/,如需转载,请注明出处,否则将追究法律责任。

你可能感兴趣的:(oracle查询语句not,in)