今天来深究个没有意义的东西:
很多人都知道用null值来进行比较是没有意义的,但是,大家是否有真正去实践过呢?试试看会不会出现一些奇怪的现象。
我们先来看看下面的两个结果(在10g上测试):


是不是感觉很奇怪?我只不过是换了个顺序来与null进行比较过滤,却出来不同的结果,按理说应该都查不出数据才对。
现在看看他们的执行计划:


显然,两条语句走了不同的执行路径。一种进行了过滤,另外一个没有。目测这是10g中的一个bug吧。
这个在里面还是讨论的挺激烈的,一个同事在11g上测试了下,两种写法都没有得出结果:

显然这个bug在11g中修复了。
本文探讨了在Oracle 10g中使用NULL值进行比较时出现的不同结果现象及其背后的原因,并对比了Oracle 11g中的表现差异,揭示了一个潜在的bug。
1313

被折叠的 条评论
为什么被折叠?



