文档章节

奇妙的NULL值,你知道多少

彭泽0902
 彭泽0902
发布于 2016/11/24 18:47
字数 1320
阅读 3
收藏 0
点赞 0
评论 0

《NULL值的多义性分析》

     谈到NULL值,很多人都是很熟悉,但是深入了解后,又感觉到陌生,对其含义和用法,都无法很准确的理解。NULL在数据库和编程语言中,存在的意义和附带的含义不同。

    NULL这个概念,在数据库中产生的时候就存在异议。NULL值的意义现在主流的想法为:“未知值或不确定的值”。至于是否应该被视为未知值或不确定的值,存在较大的争议。

    NULL值在编程语言中的意思为“空的引用”,即变量只是申明了,但没有实例化,在内存中没有分配内存。

由于NULL值在编程语言和数据库中的含义存在差异,导致对NULL值很难把握,现在就来谈一下NULL值在数据库中的含义和在编程语言中的含义和用法。

 

 一.NULL值在数据库中的含义与用法:

    1.NULL值在数据库中的含义:

        NULL值既不是为零,也不是空白,NULL值实际是指未知值或不确定值,缺少的数据。

 

    2.NULL值的用法:

       NULL在数据库中的含义是不确定的,这样可以使数据库操作人员区分故意记录为零的数据及在系统中未记录的数据,或者特意输入NULL的数据。

3.NULL值的不确定性所带来的作用:

     (1)在(值的)计算或比较中不能使用它。

     (2)NULL值相互之间并不相等,因此NULL之间无法比较大小。(类似于数学中的无穷大之间的比较)

     (3)在计算类似AVG、SUM、MAX COUNT这样的聚合函数时,会忽略包含NULL值的列。

     (4)在查询GROUP BY子句中出现包含NULL值的列时,查询输出中仅有一行包含NULL值。

 

 4.各种数据库平台对NULL的处理方式:

     (1)在oracle数据库中,一个NULL字符串,是以NULL值插入的。

     (2)在SQL Server、MySQL等数据库中,是以VARCHAR和CHAR列中插入空字符串。

    

二.NULL值在编程语言中含义和用法:

     NULL值在编程语言中的含义与用法(主要编程语言:C#,JAVA等面向对象的语言)

   1.面向对象的编程语言中(主要编程语言:C++,C#,JAVA)类型的划分:

      面向对象的编程语言中将数据类型划分为:值类型和引用类型。(都可以为泛型类型)

        (备注:C++,C#具有第三种类型:指针类型)

      说明:值类型和引用类型的区别---值类型的变量直接包含了它们的数据,引用类型的变量只保存了指向它们数据的引用,数据通常也称为对象。(任何类型的值都可以被当作是一个对象)

   2.编程语言中的NULL含义:

      空的引用(变量只定义了,但未赋值),NULL与所有的引用类型都是兼容的,代表缺失某个实例。

   3.数据类型中的NULL值意义:

     (1).值类型:只要是可空值类型的值类型的值类型变量都可以包含NULL值;对于不可为空值的值类型,则有一个对应的可空值类型表示了和它相同的值的集合加上NULL值。

(2).Bool类型:在C/C++中,一个整数零或者浮点数零,或空指针,都可以表示成布尔值false,相反则为true;在c#和java中,转换必须通过显示地将整数或浮点数值和零比较,或者显示地比较对象引用和NULL;

(注:在比较NULL的时候,非布尔值不能转换成布尔值。)

(3).引用类型:引用类型的值是一个指向某个类型实例的引用,这个实例叫做对象,特殊只NULL和所有的引用类型都是兼容的,代表缺失某个实例。

   4.NULL值在编程语言中的意义:

       (1).空对象:是一种变体称为空迭代器模型式,它使得在组合层次结构中遍历各个节点的操作对客户端透明(客户端可以使用相同的逻辑来遍历组合和叶子节点)

      (2).空对象的意义:最有用的地方在于它更靠近数据,因为对象表示的是问题空间内的实体。

三.NULL值在编程语言和数据库之间数据操作处理:

1.编程语言中的数据如何写入数据库:

   (1).在通过数据库连接(java中使用JDBC,C#应用对应的数据源连接数据库),在连接成功后,获取数据库中的数据,SQL中的NULL被映射到Java(C#)中的null。这可能会导致人们认为类似Java(C#)中null==null的情况,SQL中也存在NULL= NULL。

 2.编程语言如何从数据库中取出值,判断是否为NULL:

    (1).将取出的数据转化为字符串类型,然后进行判断。

    (2).利用语言提供的方法判断。(C#中使用DBNull或isnull)

        

     

© 著作权归作者所有

共有 人打赏支持
彭泽0902
粉丝 0
博文 44
码字总数 57771
作品 0
武汉
高级程序员
2017年河北省大学生程序设计竞赛 奇妙糖果屋 【二进制+异或】

奇妙糖果屋 Time Limit : 3000/1000ms (Java/Other) MemoryLimit : 65535/32768K (Java/Other) Total Submission(s) : 13 Accepted Submission(s) :11 Problem Description 奇异王国里有很多......

my_sunshine26
2017/11/25
0
0
执行目标文件引发的问题:syntax error: word unexpected (expe...

今天不小心把一个目标文件当成了可执行文件放到开发板上进行执行,结果出现了这样一个问题:./hello_qt: line 1: syntax error: word unexpected (expecting ")"),因为以前没有碰到过这事,...

水海云
2013/03/22
0
0
Android 一起来看看 ThreadLocal

前言 说起 ThreadLocal,大家可能会比较陌生,但是如果想要比较好地理解 Android 的消息机制,ThreadLocal 是必须要掌握的,这是因为 Looper 的工作原理,就跟 ThreadLocal 有很大的关系,理...

developerHaoz
2017/09/24
0
0
Android 一起来看看 ThreadLocal

前言 说起 ThreadLocal,大家可能会比较陌生,但是如果想要比较好地理解 Android 的消息机制,ThreadLocal 是必须要掌握的,这是因为 Looper 的工作原理,就跟 ThreadLocal 有很大的关系,理...

developerHaoz
2017/09/24
0
0
js深入之原型及原型链

作者:不洗碗工作室 - 浩小生 文章出处: js深入之原型及原型链 版权归作者所有,转载请注明出处 前言 有关于原型及原型链方面的知识,总能听见身边学习玄学js的同学朋友说起,经过学习讶羽的...

不洗碗工作室
2017/12/01
0
0
这些耐用的APP你的口袋里都有吗?

  我的手机是VIVO XPLAY 3S,6英寸大屏,平时比较喜欢的手机品牌是VIVO或者OPPO的HiFi音乐机。   这也可能跟我想要往安卓的方向发展有关,不太会选择苹果的手机,下次要是换手机的话估计...

程序员客栈
2016/06/03
114
0
发现了一个很奇妙的现象

框架用的ssm 其实他是吧字段名作为key,也就是id和str 然后字段的值作为value封装成一个map 接着,奇妙的事情发生了,当key是str的时候值其实是个字符串,但是他居然可以装进这个map里 数据取出后...

Pasacal
2016/08/16
367
2
js 数据类型

我们都知道JavaScript有'字符串','数字','布尔','数组','对象','Null','Undefined'等七种数据类型,但是碰到实际应用场景,很容易搞混淆,傻傻分不清,就没法找到因为变量类型搞错导致...

雨未浓
2017/11/07
0
0
VC读写ini文件的方法

ini文件(即Initialization file),这种类型的文件中通常存放的是一个程序的初始化信息。ini文件由若干个节(Section)组成,每个Section由若干键(Key)组成,每个Key可以赋相应的值。读写ini文件...

姿势喵
02/06
0
0
奇妙的人工智能

自从Alphago诞生以来,人工智能第一次进入大众视野,仿佛一个新时代纪元的开启,引发人们前所未有的关注。在计算机技术的突破上,科技公司总是喜欢拿人们熟悉的事物开刀,如同之前IBM”深蓝”...

连陌
2017/11/29
0
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

Laravel5.5 MySQL配置、读写分离及操作

Laravel 让连接不同数据库以及对数据库进行增删改查操作: 参考:http://laravelacademy.org/post/854.html 配置读写分离 应用的数据库配置位于 config/database.php(但是数据库用户及密码等...

MichaelShu
7分钟前
0
0
Linux 查看用户

存储帐号的文件:/etc/passwd 存储密码的文件:/etc/shadow 查看当前系统所有用户 grep bash /etc/passwd root修改普通用户的密码 sudo passwd user_name 然后连续两次输入新的用户密码即可...

yeahlife
14分钟前
0
0
Webpack使用nodemon实时打包编译

业务场景: 1.编写一个npm组件包并且link到了项目文件中 2.需要不断的修改并run build编译npm包并且在项目run dev 查看效果 3.问题: 每次改完npm包都要手动run build编译十分的麻烦且低效,可不...

JamesView
25分钟前
0
0
电脑炸了,浪费我好几天时间,还是简要记下来吧

我的小本本一直在兢兢业业的干活,然而前几天说炸就炸了...... 爆炸现场: 软件: windows10 pro + EIS11+ 360卫士 BIOS:N1DET98W 2.24 硬件: Xeon E3 1505-V5 nv-M3000M thinkpadP70:20E...

Oh_really
29分钟前
0
0
Git之branch和checkout

1.branch是查看、创建、删除分支 #>git branch --helpNAME git-branch - List, create, or delete branchesSYNOPSIS git branch [--color[=<when>] | --no-color] [......

汉斯-冯-拉特
31分钟前
0
0
Mybatis拦截器之数据权限过滤与分页集成

需求场景 最近项目有个数据权限的业务需求,要求大致为每个单位只能查看本级单位及下属单位的数据,例如:一个集团军下属十二个旅,那么军级用户可以看到所有数据,而每个旅则只能看到本旅部...

佛系程序猿灬
40分钟前
9
0
SpringCloud 微服务 (十六) 服务追踪 Zipkin

问题 在服务中,有一个接口,该A接口中又调用了其他服务的B、C、D接口,出现一个请求耗时大的问题,这时候并不知道该B、C、D接口中哪个接口造成的耗时量,然后比如确定C服务接口出现的耗时量大,但...

___大侠
今天
0
0
Java面试基础篇——第八篇:抽象类与接口的区别

1.抽象类 抽象类:如果一个类中包含有抽象方法,或这个类使用abstract关键字修饰,则称这个类是抽象类。 抽象方法是什么呢?抽象方法就是指用abstract关键字修饰的方法。 需要注意的是:抽象...

developlee的潇洒人生
今天
2
0
jsoup 相关资料

1.jsoup 2.Jsoup概述 3.jsoup入门 4.jsoup Java HTML Parser 1.11.3 API

IT追寻者
今天
1
0

没有更多内容

加载失败,请刷新页面

加载更多

下一页

返回顶部
顶部