奇妙的NULL值,你知道多少

《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)

本文参与腾讯云自媒体分享计划,欢迎正在阅读的你也加入,一起分享。

发表于

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏机器学习原理

图数据库neo4j介绍(3)——CypherCreateMatchSetDELETE REMOVE

Match (n:Person {id:'baba'}) set n.name='张三',n.age=50 return n

852
来自专栏xiaoxi666的专栏

Mybatis foreach标签含义

这种方式非常方便,我们只要把查询条件写出来,剩下的操作都由mysql来处理。而在实际场景中,为了减少底层耦合,我们一般不通过mysql中的子查询方式联表查询,而...

2121
来自专栏iOS 开发杂谈

浅谈 Objective-C Associated Objects

Associated Objects 是 Objective-C 2.0 中 Runtime 的特性之一。 在 <objc/runtime.h> 中定义的三个...

1173
来自专栏技术碎碎念

sql server 使用函数辅助查询

函数是所有语言系统下都具备的内部数据处理过程,SQL SERVER也同样内置了许多函数。在SQL SERVER中,函数是由一个或多个T-SQL语句组成的子程序。...

3494
来自专栏醉生梦死

MySQL常用函数 原

SELECT FROM_UNIXTIME(UNIX_TIMESTAMP(NOW()));

1202
来自专栏企鹅号快讯

谈谈 MySQL 隐式类型转换

来源:andyqian www.andyqian.com/2017/11/11/database/MySQLConvert/ 前言 今天我们继续回到MySQL系...

48411
来自专栏数据小魔方

MySQL基础入门系列之——字符与日期数据处理

今天这一篇分享MySQL中的字符串处理工具与日期时间处理,这一部分内容虽然看似不多,但是往往是输出处理中的的痛点。 我的MySQL数据库中已经建好了一个包含两列...

3639
来自专栏xingoo, 一个梦想做发明家的程序员

剑指OFFER之合并有序链表(九度OJ1519)

题目描述: 输入两个单调递增的链表,输出两个链表合成后的链表,当然我们需要合成后的链表满足单调不减规则。 (hint: 请务必使用链表。) 输入: 输入可能包含...

1988
来自专栏逸鹏说道

C# 温故而知新:Stream篇(二)

TextReader 和StreamReader 目录: 为什么要介绍 TextReader? TextReader的常用属性和方法 TextReader 示例...

3475
来自专栏杨建荣的学习笔记

MySQL数据类型(r3笔记第87天)

今天在本地装了一个MySQL的学习环境,简单的熟悉了一下。准备开始好好学习MySQL了。 学习编程语言我都是从数据类型入手。每种编程语言的数据类型都有自己的特点...

29610

扫码关注云+社区

领取腾讯云代金券