Oracle Null系列(一)

null 及操作

总结:除了 is null、is not null 以外,对 null 的任何操作的结果还是 null
  null 是数据库中特有的数据类型,当一条记录的某个列为 null,则表示这个列的值是未知的、是不确定的。既然是未知的,就有无数种的可能性。因此,null并不是一个确定的值。这是 null 的由来、也是 null 的基础,所有和 null 相关的操作的结果都可以从 null 的概念推导出来。
  简单的说,由于 null 存在着无数的可能,因此两个 null 既不是相等的关系,又不是不相等的关系,同样不能比较两个 null 的大小,这些操作都是没有意义的,得不到一个确切的答案的。
因此有以下结论:

  1. 判断一个字段是否为 null,应该用 is null 或 is not null,而不能用 ‘=’ 。对 null 的判断只能定性,而不能定值。
  2. 对 null 的 =、!=、>、<、>=、<= 等操作的结果都是未知的,也就算说,这些操作的结果仍然是null。
  3. 对 null 进行 +、-、*、/ 等操作的结果也是未知的,所以也是 null。

所以,很多时候会这样总结 null,除了 is null、is not null 以外,对 null 的任何操作的结果还是 null。

参考链接: oracle null值和索引
参考链接: Oracle何时为null列值建立索引

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

ts16dmy

你的鼓励将是我创作的最大动力

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

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

打赏作者

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

抵扣说明:

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

余额充值