oracle 的 null 和 空字符串('')
来源:互联网 发布:传感器数据采集 编辑:程序博客网 时间:2024/04/30 06:35
在oracle中 如何查询 字段为空的记录呢?
背景 :
表 testNull (
id int not null primary key ,
name varchar2(20) null
)
insert into testNull values(1,'a');
insert into testNull values(2,'b');
insert into testNull values(3,'');
insert into testNull values(4,'');
from:http://edgenhuang.iteye.com/blog/975567
-- oracle 将 空字符串即''当成null,测试脚本如下:
select nvl(null,-1) from dual;
select nvl('','-1') from dual;
select nvl(nvl(null,''),-1) from dual;
select nvl(trim(' '),'-1') from dual;
-- 但是要记住,null 与任何值做逻辑运算得结果都为 false,包括和null本身:
select nvl(max('1'),-1) from dual where null = '';
select nvl(max('1'),-1) from dual where null <> '';
select nvl(max('1'),-1) from dual where null = '-1';
select nvl(max('1'),-1) from dual where null <> '-1';
select nvl(max('1'),-1) from dual where null = null;
select nvl(max('1'),-1) from dual where null <> null;
-- 不过,用 is null 判断时,空字符串和 null 都 is null:
select nvl(max('1'),-1) from dual where '' is null;
select nvl(max('1'),-1) from dual where null is null;
--------------------------------------------------------------------------------------------------
-- 还要记住,null 和任何数值进行数学运算,结果都为 null:
select nvl(null + 0,-1) from dual;
-- 不过,可以使用 || 将空字符串或 null 和字符串连接
select 'a' || null || 'b' from dual;
--------------------------------------------------------------------------------------------------
-- 另,作为以下的 Oracle 内置的函数的参数时,结果也为 null:
select nvl(length(null),-1) from dual;
select nvl(trim(null),-1) from dual;
select nvl(ltrim(null),'-1') from dual;
select nvl(rtrim(null),'-1') from dual;
select nvl(rtrim(null,' '),'-1') from dual;
select nvl(soundex(null),'-1') from dual;
select nvl(SubStr(null,1),-1) from dual;
select nvl(InStr(null,1),-1) from dual;
select nvl(replace(null,'a','b'),'-1') from dual;
select nvl(min(null),'-1') from dual;
select nvl(max(null),'-1') from dual;
select nvl(sum(null),'-1') from dual;
select nvl(avg(null),'-1') from dual;
select nvl(sum(null),'-1') from dual;
-- 不过,作为以下的 Oracle 内置的函数的参数时,结果不为null:
select concat('a', null) from dual;
select concat(null, 'a') from dual;
select count(null) from dual;
-- 其他函数用的时候,也可以使用以上的方法测试
- oracle 的 null 和 空字符串('')
- oracle 的 null 和 空字符串('')
- oracle 的 null 和 空字符串('')
- oracle null和空字符串
- Oracle 空字符串和NULL
- oracle null 和空字符串
- oracle中null和空字符串的区别
- Oracle中的NULL和空字符串
- Oracle中的NULL和空字符串
- Oracle的 NULL 与 空字符串''
- NULL字符串和空字符串的区别
- NULL和空字符串的布尔值
- 空字符串(''),NULL和0的关系
- Java空字符串和null的区别
- java--空字符串""和null的区别
- Null、Nothing和字符串空的区别
- Java-空字符串""和null的区别
- null 和 空字符串的不同
- html标签Object的功能
- 给未来的你
- AS3字符操作
- 敏捷开发“松结对编程”系列之七:问题集之一
- mysql修改默认字符和默认存储引擎
- oracle 的 null 和 空字符串('')
- SAP 通过事务代码与屏幕变式(SHD0)控制控制用户界面的某些字段,以控制生产订单的调度类型为例
- 一步一步学Streams
- Visual Studio 2005 Business Intelligence 自带的数据挖掘技术
- 可动态布局的Android抽屉之基础
- Android禁止横竖屏和解决切换屏幕时重启Activity的方法
- Linux添加新硬盘并分区格式化
- Velocity java开发指南
- WPF Layout Control