加入收藏 | 设为首页 | 会员中心 | 我要投稿 李大同 (https://www.lidatong.com.cn/)- 科技、建站、经验、云计算、5G、大数据,站长网!
当前位置: 首页 > 百科 > 正文

关于oracle中 != 及 null 使用注意点

发布时间:2020-12-12 15:47:22 所属栏目:百科 来源:网络整理
导读:title stepname 关于继续开展下半年度集团早高峰保驾工作的通知 传阅 关于继续开展下半年度集团早高峰保驾工作的通知 null 关于配合国资委协同办公平台统一权限配置的相关事宜 null 执行如下语句: select t.title,t.stepname from t_todo_item t where t.lo


title stepname

关于继续开展下半年度集团早高峰保驾工作的通知 传阅

关于继续开展下半年度集团早高峰保驾工作的通知 null

关于配合国资委协同办公平台统一权限配置的相关事宜 null


执行如下语句:

select t.title,t.stepname from t_todo_item t where t.loginname='ST/G00100000161' and t.stepname!='传阅'

返回结果为空;

执行如下语句,结果才是希望得到的结果(stepName!='传阅')

关于继续开展下半年度集团早高峰保驾工作的通知null
关于配合国资委协同办公平台统一权限配置的相关事宜 null

因为null 不能用 = 或 != 来作为判断,只能使用 is null 或者 is not null

所以当 stepname!='传阅'时,null 未符合条件,故第一句的sql 是错误的。

也可以使用 nvl 函数

select t.title,t.stepname from t_todo_item t where t.loginname='ST/G00100000161' and nvl(t.stepname,'123')!='传阅'


总之,需要注意的就是Oracle中的 null 不能用 =及!=用来比较 ,只能使用is null 或者 is not null,

当字段中有null时,需要区别对待。

说明:
1、等价于没有任何值、是未知数。
2、NULL与0、空字符串、空格都不同。

3、对空值做加、减、乘、除等运算操作,结果仍为空。
4、NULL的处理使用NVL函数。
5、比较时使用关键字用“is null”和“is not null”。
6、空值不能被索引,所以查询时有些符合条件的数据可能查不出来,count(*)中,用nvl(列名,0)处理后再查。
7、排序时比其他数据都大(索引默认是降序排列,小→大),所以NULL值总是排在最后。



原文地址:http://blog.csdn.net/z69183787/article/details/9278375

(编辑:李大同)

【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容!

    推荐文章
      热点阅读