Oracle中的NULL、’’(空字符串)以及’_’(空格)
本文首发于 http://youngzy.com/
在Oracle中使用 null,''(空字符串),'_'(空格)时,有没有遇到问题?产生疑惑?
null和’’(空字符串)是一个意思
注: 为了便于区分空字符串和空格,下面的示例均以 _ 代表空格
举个例子:
--建表
create table tbl_a (col_a varchar2(1), col_b int); -- 造数据
insert into tbl_a values(‘_’, 1); -- 插入空格
insert into tbl_a values(‘’, 2); -- 插入空字符串
insert into tbl_a values(null, 3); -- 插入NULL
以上SQL执行成功后,执行 select 来检查:
select count(*) from tbl_a; -- 结果是 3
select count(*) from tbl_a where col_a = ‘_’; -- 结果是 1
select count(*) from tbl_a where col_a = ‘’; -- 结果是 0
select count(*) from tbl_a where col_a is null; -- 结果是 2
注意: 由于 ‘’ (空串)默认被转换成了
NULL,不能使用= ‘’作为查询条件。也不能用is ‘’。虽然不会有语法错误,但是不会有结果集返回。 只能用is null。不等于就是
is not null。
进一步验证:
select nvl(col_a, ‘a’) from tbl_a;
结果:
| NVL(COL_A,’A’) | |
|---|---|
| 1 | |
| 2 | a |
| 3 | a |
原来,在Oracle中,null和’’(空字符串)是一个意思。
分析函数与NULL
在使用AVG,MAX,SUM,COUNT等函数时,为NULL的纪录会被忽略。
再插入几条数据:
insert into tbl_a values(null, null); -- 插入NULL
-- 执行成功。
-- 再次证明,’’ 被当作了null处理.
-- 因为该字段是 int 类型,如果是字符串,执行会报错
insert into tbl_a values(‘a’, ‘’);
查看数据:
select * from tbl_a;
结果如下:
| COL_A | COL_B |
|---|---|
| _ | 1 |
| 2 | |
| 3 | |
| a |
_ 代表空格
其余空白处表示 NULL
验证:
select AVG(col_b) from tbl_a; -- 结果为 2 ,NULL的纪录行忽略掉了
select MAX(col_b) from tbl_a; -- 结果为 3
select SUM(col_b) from tbl_a; -- 结果为 6
select COUNT(col_b) from tbl_a; -- 结果为 3
select COUNT(col_a) from tbl_a; -- 结果为 2
select COUNT(*) from tbl_a; -- 结果为 5
排序时,NULL作为无穷大处理。
select * from tbl_a order by col_b desc ;
结果如下:
| COL_A | COL_B |
|---|---|
| a | |
| 3 | |
| 2 | |
| _ | 1 |
参考:http://blog.csdn.net/weiwenhp/article/details/7035327
Oracle中的NULL、’’(空字符串)以及’_’(空格)的更多相关文章
- 【转】oracle中的NULL、''(空字符串)以及'_'(空格)
在Oracle中使用null,''(空字符串),'_'(空格)时,有没有遇到问题?产生疑惑? 1.NULL和''(空字符串)是一个意思 注:为了便于区分空字符串和空格,下面的示例均以'_'代表空格. ...
- Oracle中的null与空字符串''的区别
含义解释:问:什么是NULL?答:在我们不知道具体有什么数据的时候,也即未知,可以用NULL,我们称它为空,ORACLE中,含有空值的表列长度为零.ORACLE允许任何一种数据类型的字段为空,除了以下 ...
- Oracle中长度为0字符串与null等价
不试不知道,Oracle中,长度为0的字符串'' 居然与null等价! 众所周知,null代表空,什么都不存在,而一个字符串'',虽然长度为0,但毕竟已经是一个字符串,二者怎么能等价,混为一谈呢. 在 ...
- DB中字段为null,为空,为空字符串,为空格要怎么过滤取出有效值
比如要求取出微信绑定的,没有解绑的 未绑定,指定字段为null 绑定的,指定字段为某个字符串 解绑的,有的客户用的是更新指定字段为1,有的客户更新指定字段为‘1’ 脏数据的存在,比如该字段为空字符 ...
- 刚从一道题发现的一些东西,PHP笔记,关于extract和null 空字符串
队友发给我的一道extract变量的最基础的题目,他发现了一些问题,当传入shiyan=&flag=0时出flag,当传入shiyan=0&flag=0时不出flag,传入shiyan ...
- Oracle中的null
测试数据:公司部分员工基本信息
- oracle 中的null与''
1.先看看Null与''在oracle中的表现 C:\Users\zen>sqlplus hr/hr SQL Production :: Copyright (c) , , Oracle. Al ...
- 关于JavaScript中0、空字符串、'0'是true还是false的总结
最近被问到关于js中空字符串是true还是false得问题,一时间没想起来,现在在chrome的console面板上输出代码测试一下. "" == false 结果是true ...
- oracle中空值null的判断和转换:NVL的用法
1.NULL空值概念 数据库里有一个很重要的概念:空值即NULL.有时表中,更确切的说是某些字段值,可能会出现空值, 这是因为这个数据不知道是什么值或根本就不存在. 2.NULL空值判断 空值不等同于 ...
随机推荐
- Vue相关开源项目库汇总(史上最全)
偶尔在网上看到的,先保存着,以备不时之需 https://www.jianshu.com/p/e37f4dde49a2 better-scroll:是一款重点解决移动端(未来可能会考虑 PC 端)各种 ...
- 了解CSS/CSS3原生变量var (转)
一.变量是个好东西 在任何语言中,变量的有一点作用都是一样的,那就是可以降低维护成本,附带还有更高性能,文件更高压缩率的好处. 随着CSS预编译工具Sass/Less/Stylus的关注和逐渐流行,C ...
- Spring quartz 单机、集群+websocket集群实现文本、图片、声音、文件下载及推送、接收及显示
相关环境 Nginx,Spring5.x当前(要选择4.0+),tomcat9.x或8.x都可以,Quartz 2.x集群(实际运用是Quartz的集群模式和单机模式共存的) 测试面页:http:// ...
- nginx配置实例
user root root; worker_processes ; #error_log logs/error.log; #error_log logs/error.log notice; #err ...
- mac的vscode配置使用zsh
配置文件 "terminal.integrated.shell.osx": "zsh"
- SpringBoot项目获取ApplicationContext来GetBean的方法
一.简介 我们开发时,经常遇到有些实例需要动态创建,比如有构造函数的组件等.这时候,Spring时我们有ClassPathXmlApplicationContext,但是在Spring Boot时,我 ...
- 每天一个linux命令:chown
1.命令简介 chown(Change owner) 用来改变某个文件或目录的所有者和所属的组,该命令可以向某个用户授权,使该用户变成指定文件的所有者或者改变文件所属的组.用户可以是用 ...
- xhr是什么文件类型?
xhr:XMLHttpRequest在后台与服务器交换数据,这意味着可以在不加载整个网页的情况下,对网页某部分的内容进行更新. 是Ajax的一种用法,而Ajax并不是一门语言,只是一种不需要加载整个网 ...
- 使用viewport中的vm来适配移动端页面
前言 作为一个小前端,经常要和H5打交道,这就面临着不同终端的适配问题. Flexible方案通过Hack手段来根据设备的dpr值相应改变<meta>标签中viewport的值,给我更贴切 ...
- Vue Resource root options not used?
I specify a root options in my Vue-Resource in my main.js file, but when I do the request, it does n ...