含义解释:

问:什么是NULL?

答:在我们不知道具体有什么数据的时候,也即未知,可以用NULL,我们称它为空,ORACLE中,含有空值的表列长度为零。

ORACLE允许任何一种数据类型的字段为空,除了以下两种情况:

1、主键字段(primary key),

2、定义时已经加了NOT NULL限制条件的字段

说明:

1、等价于没有任何值、是未知数。

2、NULL与0、空字符串、空格都不同。

3、对空值做加、减、乘、除等运算操作,结果仍为空。

4、NULL的处理使用NVL函数。

5、比较时使用关键字用“is null”和“is not null”。

6、空值不能被索引,所以查询时有些符合条件的数据可能查不出来,count(*)中,用nvl(列名,0)处理后再查。

7、排序时比其他数据都大(索引默认是降序排列,小→大),所以NULL值总是排在最后。

使用方法:

SQL> select 1 from dual where null=null;

没有查到记录

SQL> select 1 from dual where null=”;

没有查到记录

SQL> select 1 from dual where ”=”;

没有查到记录

SQL> select 1 from dual where null is null;

SQL> select 1 from dual where nvl(null,0)=nvl(null,0);

对空值做加、减、乘、除等运算操作,结果仍为空。

SQL> select 1+null from dual;

SQL> select 1-null from dual;

SQL> select 1*null from dual;

SQL> select 1/null from dual;

查询到一个记录.

注:这个记录就是SQL语句中的那个null

设置某些列为空值

update table1 set 列1=NULL where 列1 is not null;

现有一个商品销售表sale,表结构为:

month    char(6)      –月份

sell    number(10,2)   –月销售金额

create table sale (month char(6),sell number);

insert into sale values(‘200001’,1000);

insert into sale values(‘200002’,1100);

insert into sale values(‘200003’,1200);

insert into sale values(‘200004’,1300);

insert into sale values(‘200005’,1400);

insert into sale values(‘200006’,1500);

insert into sale values(‘200007’,1600);

insert into sale values(‘200101’,1100);

insert into sale values(‘200202’,1200);

insert into sale values(‘200301’,1300);

insert into sale values(‘200008’,1000);

insert into sale(month) values(‘200009’);(注意:这条记录的sell值为空)

commit;

共输入12条记录

SQL> select * from sale where sell like ‘%’;

MONTH SELL


200001 1000

200002 1100

200003 1200

200004 1300

200005 1400

200006 1500

200007 1600

200101 1100

200202 1200

200301 1300

200008 1000

查询到11记录.

结果说明:

查询结果说明此SQL语句查询不出列值为NULL的字段

此时需对字段为NULL的情况另外处理。

SQL> select * from sale where sell like ‘%’ or sell is null;

SQL> select * from sale where nvl(sell,0) like ‘%’;

MONTH SELL


200001 1000

200002 1100

200003 1200

200004 1300

200005 1400

200006 1500

200007 1600

200101 1100

200202 1200

200301 1300

200008 1000

200009

查询到12记录.

Oracle的空值就是这么的用法,我们最好熟悉它的约定,以防查出的结果不正确。

但对于char 和varchar2类型的数据库字段中的null和空字符串是否有区别呢?

作一个测试:

create table test (a char(5),b char(5));

SQL> insert into test(a,b) values(‘1’,’1’);

SQL> insert into test(a,b) values(‘2’,’2’);

SQL> insert into test(a,b) values(‘3’,”);–按照上面的解释,b字段有值的

SQL> insert into test(a) values(‘4’);

SQL> select * from test;

SQL> select * from test where b=”;—-按照上面的解释,应该有一条记录,但实际上没有记录

未选定行

SQL> select * from test where b is null;—-按照上面的解释,应该有一跳记录,但实际上有两条记录。

SQL>update table test set b=” where a=’2’;

SQL> select * from test where b=”;

未选定行

SQL> select * from test where b is null;

测试结果说明,对char和varchar2字段来说,”就是null;但对于where 条件后的” 不是null。

对于缺省值,也是一样的!

Oracle中Null与空字符串' '的区别相关推荐

  1. Oracle中Null与空字符串''的区别

    http://read.newbooks.com.cn/info/172049.html Oracle中Null与空字符串''的区别 来源:CSDN   作者:jsjzzh   发布时间:2007-1 ...

  2. Django与SQL语言中——NULL与空字符串的区别

    SQL有指定空值的独特方式,它把空值叫做NULL. Null在数据库中表示 不知道的数据,主要有3种意思: 1)知道数据存在,但不知道具体值. 2)不知道数据是否存在. 3)数据不存在. 在SQL中, ...

  3. oracle数据库null和空字符串区别,null和空字符串('')的区别

    在Java开发中,我们需要常常判断是否值为null,尤其在xml数据交互过程中,我们判断某一个报文的值是否为null时候,经常需要用三目运算判断:如果值为null,则赋值空字符串(insert数据库时 ...

  4. mysql的字段空格是null_MySQL中NULL与空字符串 空格问题

    一些刚刚接触MySQL的孩子,经常会错误的认为NULL与空字符串' '是相同的.这看似是一件不重要的事情,但是在MySQL中,这两者是完全不同的.NULL是指没有值,而''则表示值是存在的,只不过是个 ...

  5. mysql null值和空格_MySQL中NULL与空字符串空格问题

    一些刚刚接触MySQL的孩子,经常会错误的认为NULL与空字符串' '是相同的.这看似是一件不重要的事情,但是在MySQL中,这两者是完全不同的.NULL是指没有值,而''则表示值是存在的,只不过是个 ...

  6. null和空字符串('')的区别

    在Java开发中,我们需要常常判断是否值为null,尤其在xml数据交互过程中,我们判断某一个报文的值是否为null时候,经常需要用三目运算判断:如果值为null,则赋值空字符串(insert数据库时 ...

  7. Oracle 与 Mysql NULL值,空字符串''的区别

    Oracle(null等同于空字符'') 1.oracle插入空字符串默认替换成null 2.oracle查询(null和被替换的空字符)时使用 is null/is not null 3.使用聚合函 ...

  8. Sqoop导入hive中null是空字符串还是‘null‘的问题(关注)

    Sqoop导入hive中null字符串处理为NULL 其中注意 这个是转为空字符串而不是'null'这种. 可以用ifnull转化的 这种就是'null'

  9. Mysql 中null与空字符串陷进

    前阵子在更新数据库时候碰见一个新增表的语句,发现插入的空值自动填充的值,很是费解,下面我们先来说说案例,以下是模仿的测试: 首先创建一个表:create table ceshi(ID INT ,cre ...

最新文章

  1. python中re模块怎么导入_python如何导入re模块
  2. xul中的快捷键及命令响应
  3. pcie inbound、outbound及EP、RC间的互相訪问
  4. NVisionXRFBXConverter(Beta版)实践课程
  5. 2013科目四考试_2013驾考科目四考试流程
  6. 物联网通信-期末复习
  7. 手机射频功放指标介绍
  8. 四元数与三维向量相乘运算法则
  9. 中国60家最强汽车初创在此!芯片厂高调入局,智能网联强势霸榜
  10. 在EXCEL中生成服从三角分布随机数的方法
  11. Windows安全更新出现0x800f081f错误解决方案
  12. 图像去雾开源数据集资源汇总
  13. 智能+建筑>智能建筑
  14. JavaWeb开发技术学习笔记(十四)——集群
  15. 苹果电脑怎么无痕浏览网页
  16. 免root运行青龙面版和傻妞机器
  17. 联想g490安装linux网卡,联想g490配置和参数详解
  18. 安卓 Android的Bugly SDK的接入
  19. python藏头诗_Python简单实现表白藏头诗
  20. Whale 帷幄技术周大咖分享:AI 迎来大洗牌

热门文章

  1. 【机器学习基础】数学推导+纯Python实现机器学习算法12:贝叶斯网络
  2. GitHub上能让你重拾学习热情的AI项目:权游预测/AI作画/与AlphaZero对弈
  3. 统计学习方法第二十章作业:潜在狄利克雷分配 LDA 吉布斯抽样法算法 代码实现
  4. Transformer 向轻量型迈进,微软与中科院提出两路并行的 Mobile-Former
  5. Think as developer, 从深入理解业务实现框架开始
  6. 易创课堂成都站给你寄来一包干货,请注意查收
  7. Redis和mysql数据怎么保持数据一致的?
  8. echarts版本折线图
  9. 20162321王彪 2017-2018-1 《程序设计与数据结构》第三周学习总结
  10. Maven编译时提示:不兼容的类型