Oracle中Null与空字符串' '的区别
含义解释:
问:什么是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与空字符串' '的区别相关推荐
- Oracle中Null与空字符串''的区别
http://read.newbooks.com.cn/info/172049.html Oracle中Null与空字符串''的区别 来源:CSDN 作者:jsjzzh 发布时间:2007-1 ...
- Django与SQL语言中——NULL与空字符串的区别
SQL有指定空值的独特方式,它把空值叫做NULL. Null在数据库中表示 不知道的数据,主要有3种意思: 1)知道数据存在,但不知道具体值. 2)不知道数据是否存在. 3)数据不存在. 在SQL中, ...
- oracle数据库null和空字符串区别,null和空字符串('')的区别
在Java开发中,我们需要常常判断是否值为null,尤其在xml数据交互过程中,我们判断某一个报文的值是否为null时候,经常需要用三目运算判断:如果值为null,则赋值空字符串(insert数据库时 ...
- mysql的字段空格是null_MySQL中NULL与空字符串 空格问题
一些刚刚接触MySQL的孩子,经常会错误的认为NULL与空字符串' '是相同的.这看似是一件不重要的事情,但是在MySQL中,这两者是完全不同的.NULL是指没有值,而''则表示值是存在的,只不过是个 ...
- mysql null值和空格_MySQL中NULL与空字符串空格问题
一些刚刚接触MySQL的孩子,经常会错误的认为NULL与空字符串' '是相同的.这看似是一件不重要的事情,但是在MySQL中,这两者是完全不同的.NULL是指没有值,而''则表示值是存在的,只不过是个 ...
- null和空字符串('')的区别
在Java开发中,我们需要常常判断是否值为null,尤其在xml数据交互过程中,我们判断某一个报文的值是否为null时候,经常需要用三目运算判断:如果值为null,则赋值空字符串(insert数据库时 ...
- Oracle 与 Mysql NULL值,空字符串''的区别
Oracle(null等同于空字符'') 1.oracle插入空字符串默认替换成null 2.oracle查询(null和被替换的空字符)时使用 is null/is not null 3.使用聚合函 ...
- Sqoop导入hive中null是空字符串还是‘null‘的问题(关注)
Sqoop导入hive中null字符串处理为NULL 其中注意 这个是转为空字符串而不是'null'这种. 可以用ifnull转化的 这种就是'null'
- Mysql 中null与空字符串陷进
前阵子在更新数据库时候碰见一个新增表的语句,发现插入的空值自动填充的值,很是费解,下面我们先来说说案例,以下是模仿的测试: 首先创建一个表:create table ceshi(ID INT ,cre ...
最新文章
- python中re模块怎么导入_python如何导入re模块
- xul中的快捷键及命令响应
- pcie inbound、outbound及EP、RC间的互相訪问
- NVisionXRFBXConverter(Beta版)实践课程
- 2013科目四考试_2013驾考科目四考试流程
- 物联网通信-期末复习
- 手机射频功放指标介绍
- 四元数与三维向量相乘运算法则
- 中国60家最强汽车初创在此!芯片厂高调入局,智能网联强势霸榜
- 在EXCEL中生成服从三角分布随机数的方法
- Windows安全更新出现0x800f081f错误解决方案
- 图像去雾开源数据集资源汇总
- 智能+建筑>智能建筑
- JavaWeb开发技术学习笔记(十四)——集群
- 苹果电脑怎么无痕浏览网页
- 免root运行青龙面版和傻妞机器
- 联想g490安装linux网卡,联想g490配置和参数详解
- 安卓 Android的Bugly SDK的接入
- python藏头诗_Python简单实现表白藏头诗
- Whale 帷幄技术周大咖分享:AI 迎来大洗牌
热门文章
- 【机器学习基础】数学推导+纯Python实现机器学习算法12:贝叶斯网络
- GitHub上能让你重拾学习热情的AI项目:权游预测/AI作画/与AlphaZero对弈
- 统计学习方法第二十章作业:潜在狄利克雷分配 LDA 吉布斯抽样法算法 代码实现
- Transformer 向轻量型迈进,微软与中科院提出两路并行的 Mobile-Former
- Think as developer, 从深入理解业务实现框架开始
- 易创课堂成都站给你寄来一包干货,请注意查收
- Redis和mysql数据怎么保持数据一致的?
- echarts版本折线图
- 20162321王彪 2017-2018-1 《程序设计与数据结构》第三周学习总结
- Maven编译时提示:不兼容的类型