【Oracle】关于null的讨论

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

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

今天来深究个没有意义的东西:

很多人都知道用null值来进行比较是没有意义的,但是,大家是否有真正去实践过呢?试试看会不会出现一些奇怪的现象。

我们先来看看下面的两个结果(在10g上测试):



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

现在看看他们的执行计划:



显然,两条语句走了不同的执行路径。一种进行了过滤,另外一个没有。目测这是10g中的一个bug吧。

这个在里面还是讨论的挺激烈的,一个同事在11g上测试了下,两种写法都没有得出结果:


显然这个bug在11g中修复了。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值