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

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

 

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

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

进一步验证:

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的纪录会被忽略。

再插入几条数据:

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

 

查看数据:

select * from tbl_a; 

 

结果如下:
COL_A COL_B
_ 1
  2
  3
   
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 

 

排序时,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

 

阅读原文

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/109144.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 2018年中国民营企业进出口12.1万亿元 增长12.9%

    2018年中国民营企业进出口12.1万亿元 增长12.9%

    2021年6月21日
    85
  • 数组转对象,对象转数组对不对_对象数组初始化

    数组转对象,对象转数组对不对_对象数组初始化<scripttype=”text/javascript”>//数组转对象vara=[1,2,3,4]varobj={…a}//{0:1,1:2,2:3,3:4}varobj2={}a.forEach((item,index)=>{obj2[index]=item})//{0:1,1:2,2:3,3:4}functiontoObj(a.

    2025年10月23日
    2
  • macos安装svn软件_windows安装svn服务器

    macos安装svn软件_windows安装svn服务器我们都知道在Windows安装SVN客户端一般都用TortoiseSVN,在MACOS上也有一个类似TortoiseSVN的,就是SnailSVNLite,它的操作跟TortoiseSVN很像,关键还是免费的。安装过程:1.从AppStore上下载SnailSVNLite。2.下载完成,打开软件,在【SVN设置】下,看下面提示设置好3个路径①~/.ssh查找对应的文件夹,如…

    2022年10月20日
    4
  • c语言中ff用16进制怎么表示什么,0xff(十六进制0xff表示什么)

    c语言中ff用16进制怎么表示什么,0xff(十六进制0xff表示什么)0xff从数值上看,0xff表示一个十六进制数FF,也就是十进制的255。从电平高低来看,比如读取P1口得到0xFF,表示P1口8个引脚都是高电平。以0x开始的数据表示16进制,0xff换成十进制为255。A,B,C,D,E,F这五个字母来分别表示10,11,12,13,14,15。16进制变十进制:f表示15。第n位的权值为16的n次方,由右.我现在要把这个16进制的数转换成2进制的或者是10…

    2022年6月19日
    104
  • 用Python进行web开发需要学习什么?「建议收藏」

    第一步:HTMLHTML是网页的核心,学好HTML是成为Web开发人员的基本条件。HTML很容易学习的,但也很容易误用,要学精还得费点功夫。  随着HTML5的发展和普及,了解HTML5也将成为Web开发人员的必修课。  涉及到网页外观时,就需要学习CSS了,它可以帮你把网页做得更美观。  利用HTML和CSS模拟一些你所见过的网站的排版和布局(色彩,图片,文字样式等等)。第二步:学习javascript,了解DOMJavaScript是一种能让你的网页更加生动活泼的程序语言。学习JavaScr

    2022年4月11日
    39
  • 详解卷积神经网络(CNN)

    详解卷积神经网络(CNN)卷积神经网络(ConvolutionalNeuralNetwork,CNN)是一种前馈神经网络,它的人工神经元可以响应一部分覆盖范围内的周围单元,对于大型图像处理有出色表现。

    2022年6月21日
    24

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号