在Oracle中使用null,''(空字符串),'_'(空格)时,有没有遇到问题?产生疑惑?

1、NULL和''(空字符串)是一个意思

  注:为了便于区分空字符串和空格,下面的示例均以'_'代表空格。

  举个例子:

  1. --建表
  2. create table tbl_a (col_a varchar2(1), col_b int);
  3.  
  4. -- 造数据
  5. insert into tbl_a values(‘_’, 1); -- 插入空格
  6. insert into tbl_a values(‘’, 2); -- 插入空字符串
  7. insert into tbl_a values(null, 3); -- 插入NULL

  以上SQL执行成功后,执行select来检查:

  1. select count(*) from tbl_a; -- 结果是 3
  2. select count(*) from tbl_a where col_a = _’; -- 结果是 1
  3. select count(*) from tbl_a where col_a = ‘’; -- 结果是 0
  4. select count(*) from tbl_a where col_a is null; -- 结果是 2

  注意:由于''(空字符串)默认被转换成了NULL,不能使用 = ''作为查询条件。也不能用 is ''。虽然不会有语法错误,但是不会有结果集返回。只能用is null,不等于就是 is not null。

  进一步验证:

  1. select nvl(col_a, a’) from tbl_a;

  结果:

  原来,在Oracle中,null和''(空字符串)是一个意思。

2、分析函数与NULL

  在使用AVG,MAX,SUM,COUNT等函数时,为NULL的记录会被忽略。

  再插入几条数据:

  1. insert into tbl_a values(null, null); -- 插入NULL
  2. -- 执行成功。
  3. -- 再次证明,’’ 被当作了null处理.
  4. -- 因为该字段是 int 类型,如果是字符串,执行会报错
  5. insert into tbl_a values(‘a’, ‘’);

  查看数据:

  1. select * from tbl_a;

  结果如下:

  注:_代表空格,其余空白处表示NULL

  验证:

  1. select AVG(col_b) from tbl_a; -- 结果为 2 NULL的纪录行忽略掉了
  2. select MAX(col_b) from tbl_a; -- 结果为 3
  3. select SUM(col_b) from tbl_a; -- 结果为 6
  4. select COUNT(col_b) from tbl_a; -- 结果为 3
  5. select COUNT(col_a) from tbl_a; -- 结果为 2
  6. select COUNT(*) from tbl_a; -- 结果为 5

3、排序时,NULL作为无穷大处理

  例:

  1. select * from tbl_a order by col_b desc ;

  结果如下:

转载自《oracle中的NULL、''(空字符串)以及'_'(空格)

【转】oracle中的NULL、''(空字符串)以及'_'(空格)的更多相关文章

  1. Oracle中的NULL、’’(空字符串)以及’_’(空格)

    本文首发于 http://youngzy.com/ 在Oracle中使用 null,''(空字符串),'_'(空格)时,有没有遇到问题?产生疑惑? null和’’(空字符串)是一个意思 注: 为了便于 ...

  2. Oracle中的null与空字符串''的区别

    含义解释:问:什么是NULL?答:在我们不知道具体有什么数据的时候,也即未知,可以用NULL,我们称它为空,ORACLE中,含有空值的表列长度为零.ORACLE允许任何一种数据类型的字段为空,除了以下 ...

  3. Oracle中长度为0字符串与null等价

    不试不知道,Oracle中,长度为0的字符串'' 居然与null等价! 众所周知,null代表空,什么都不存在,而一个字符串'',虽然长度为0,但毕竟已经是一个字符串,二者怎么能等价,混为一谈呢. 在 ...

  4. DB中字段为null,为空,为空字符串,为空格要怎么过滤取出有效值

      比如要求取出微信绑定的,没有解绑的 未绑定,指定字段为null 绑定的,指定字段为某个字符串 解绑的,有的客户用的是更新指定字段为1,有的客户更新指定字段为‘1’ 脏数据的存在,比如该字段为空字符 ...

  5. 刚从一道题发现的一些东西,PHP笔记,关于extract和null 空字符串

    队友发给我的一道extract变量的最基础的题目,他发现了一些问题,当传入shiyan=&flag=0时出flag,当传入shiyan=0&flag=0时不出flag,传入shiyan ...

  6. Oracle中的null

    测试数据:公司部分员工基本信息

  7. oracle 中的null与''

    1.先看看Null与''在oracle中的表现 C:\Users\zen>sqlplus hr/hr SQL Production :: Copyright (c) , , Oracle. Al ...

  8. 关于JavaScript中0、空字符串、'0'是true还是false的总结

    最近被问到关于js中空字符串是true还是false得问题,一时间没想起来,现在在chrome的console面板上输出代码测试一下. "" == false 结果是true    ...

  9. oracle中空值null的判断和转换:NVL的用法

    1.NULL空值概念 数据库里有一个很重要的概念:空值即NULL.有时表中,更确切的说是某些字段值,可能会出现空值, 这是因为这个数据不知道是什么值或根本就不存在. 2.NULL空值判断 空值不等同于 ...

随机推荐

  1. [译]Vulkan教程(04)基础代码

    [译]Vulkan教程(04)基础代码 General structure 通用结构 In the previous chapter you've created a Vulkan project w ...

  2. Java实现网络聊天中使用的socket API与Linux socket API之间的关系

    尝试着用Java编写一个网络聊天程序,发现总不如网上写的好,所以就直接引用了网上大神的优秀代码.代码如下: package project1; import java.awt.*; import ja ...

  3. dev c++必须修改的三处默认设置

    此文档记录参加pat考试并且以dev c++[针对5.11版本]软件作为开发工具时,必须修改的三个默认设置. 1.修改默认语言标准 Dev C++ 5.11 版本支持较新的 C 和 C++ 标准,但是 ...

  4. emojy表情的小问题

    报错内容:在emojy表情入库或者更新库的时候,会报这个错:java.sql.SQLException:Incorrect string value: '\xF0\x9F\x99\x8F\..' fo ...

  5. JVM内存模型与类加载机制

    一. java虚拟机的内存模型如图: 补习一下jvm内存模型中的各个组成部分 堆: 我们new出来的对象全部放在堆中,他是jvm所能够动态分配的最大的一块空间 优点: 内存动态分配,生命周期不必事先告 ...

  6. Kafka简明教程

    作者:柳树之 www.jianshu.com/p/7b77723d4f96 Kafka是啥?用Kafka官方的话来说就是: Kafka is used for building real-time d ...

  7. 中间件1--dubbo

    DUBBO是一个分布式服务框架,致力于提供高性能和透明化的RPC远程服务调用方案,是阿里巴巴SOA服务化治理方案的核心框架,每天为2,000+个服务提供3,000,000,000+次访问量支持,并被广 ...

  8. 关于MySql 数据库InnoDB存储引擎介绍

    熟悉MySQL的人,都知道InnoDB存储引擎,如大家所知,Redo Log是innodb的核心事务日志之一,innodb写入Redo Log后就会提交事务,而非写入到Datafile.之后innod ...

  9. zookeeper启动失败,但是状态显示已启动的原因

    今天在起zookeeper集群的时候,其他两台机子都能起起来,只有这一台机子起不起来: 对比了 这个路径下的 文件后发现多了一个这个文件 根据名字推测应该是放进程id.突然明白这个应该是上次非正常退出 ...

  10. URL跳转绕过姿势

    POC "@" http://www.target.com/redirecturl=http://whitelist.com@evil.com "\" http ...