奇妙的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)
奇妙的NULL值,你知道多少的更多相关文章
- oracle 关于null值排序
在oracle中根据字段来desc排序的话null值可能会在数据的最前面.然而有时候我们查看数据的时候并不希望能够在前面看到这些null值的排序数据. 因此我查了一下: 1.排序的时候运用nvl(). ...
- SQL中NULL值
SQL的表达式,除了IS NULL和NOT NULL以外,只要出现NULL值结果都为FALSE 简单的例子: SELECT * FROM table WHERE name!='abc' 只要name值 ...
- 关于null值的排序
关于空值null的排序问题 Oracle排序中NULL值处理的五种常用方法: 1.缺省Oracle在Order by 时缺省认为null是最大值,所以如果是ASC升序则排在最后,DESC降序则排在 ...
- SQL Server表分区的NULL值问题
SQL Server表分区的NULL值问题 SQL Server表分区只支持range分区这一种类型,但是本人觉得已经够用了 虽然MySQL支持四种分区类型:RANGE分区.LIST分区.HASH分区 ...
- TSQL 聚合函数忽略NULL值
max,min,sum,avg聚合函数会忽略null值,但不代表聚合函数不返回null值,如果表为空表,或聚合列都是null,则返回null.count 聚合函数忽略null值,如果聚合列都是null ...
- mysql null值处理详细说明
在讲null之前,我们先看一个例子 表数据如下: 3306>select * from t1; +------+-------+ | id | name | +------+-------+ | ...
- SQL SERVER使用ODBC 驱动建立的链接服务器调用存储过程时参数不能为NULL值
我们知道SQL SERVER建立链接服务器(Linked Server)可以选择的驱动程序非常多,最近发现使用ODBC 的 Microsoft OLE DB 驱动程序建立的链接服务器(Linked S ...
- SQL NULL 值【摘自W3C】
SQL NULL 值 本章讲解 IS NULL 和 IS NOT NULL 操作符. NULL 值是遗漏的未知数据.默认地,表的列可以存放 NULL 值. 如果表中的某个列是可选的,那么我们可以在不向 ...
- not子查询中有null值的时候 not in 会失效
not in子查询中有null值的时候 not in 会失效 但是 in 的子查询中有null的 不会失效
随机推荐
- MAC下使用Charles抓取安卓模拟器数据
一.安装Charles,这个不多记录 二.Charles数据乱码问题(参照这篇文章 http://blog.csdn.net/huanghanqian/article/details/52973651 ...
- vector、list、deque三者比较
1.vector是一段连续的内存块,而deque是多个连续的内存块,list是所有数据元素分开保存,可以是任何两个元素都没有连续. 2.vector的查询性能最好,并且的末端增加数据也很好,除非它重新 ...
- Java面向对象课程小结
1.什么是对象?什么是类? 类和对象的关系 定义类的方法 方法五要素 new关键字 引用类型变量的赋值 null和nullException null大小写的区别 2.方法 重载和重写 构造 方法,带 ...
- HTML打折计算价格
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html> <met ...
- (一)Linux相关内容的简介
1.Linux内核官网:www.kernel.org 2.Linux主要发行版本: (1)redhat 服务器中常见(部分功能收费); (2)Ubuntu 图形界面较好,但是服务器中很少用: (3 ...
- SQL基础--同义词
同义词的概念: 同义词是Oracle对象的别名,使用同义词访问相同的对象 可以为表.视图.存储过程.函数或另一同义词等对象创建同义词 方便访问其它用户的对象,隐藏了对象的身份 缩短对象名字的长度 同义 ...
- 你的眼睛背叛你的心:解决 .NET Core 中 GetHostAddressesAsync 引起的 EnyimMemcached 死锁问题
在我们将站点从 ASP.NET + Windows 迁移至 ASP.NET Core + Linux 的过程中,目前遇到的最大障碍就是 —— 没有可用的支持 .NET Core 的 memcached ...
- MySQL Dll语句
标签:MYSQL数据库/DBA/删除数据库表 概述 因为遇到一些事情,从发表上一篇文章到现在中间间隔了好几个月时间:在接下来的时间里会陆续发表关于mysql的一些文章,从基础到优化最后到管理,欢迎关注 ...
- Unicode编码解码在线转换工具
// Unicode编码解码在线转换工具 Unicode 是基于通用字符集(Universal Character Set)的标准来发展,并且同时也以书本的形式(The Unicode Standar ...
- ubuntu下rhythmbox歌名显示乱码问题解决
问题描述:本人装有双系统,一个是win7,另一个是ubuntu12.04LTS版本,所有的歌曲都在windows磁盘下KuGou目录中,这个时候,使用ubuntu的rhythmbox播放的歌曲的时候, ...