在 Java、C# 中,相信如果是 boolean 类型值,只有两种选择 true、false。然而,在 SQL 查询中,NULL 值的引入,使得新增了 UNKNOW ,因此,就产生了 TRUE、FALSE、UNKNOW 三种选择。

NULL :在 C#、Java 语言中,NULL 作为一个值(引用类型字段默认初始值,注意区别 NULL、空字符串区别),代表未指向内存堆空间中任何对象(此处,就不在细讲,可以去详细了解一下基本类型、引用类型在内存堆栈上存储区别)。而在数据库中,NULL 同样作为一个值,其含义可以理解为:NULL 表示该字段值不知道,而并不是代表字段没有值。

           下表来自维基百科,有关 NULL、TRUE、FALSE 参与 OR AND 非运算逻辑结果 

         

     

测试脚本 SQL  

DECLARE @Temp TABLE
(
ID INT IDENTITY PRIMARY KEY NOT NULL ,
NAME VARCHAR(50) NOT NULL,
[ADDRESS] VARCHAR(150) NULL,
MONEYDATA INT NULL
)
INSERT INTO @Temp
SELECT '张全蛋','台湾富土康',1000
UNION ALL
SELECT '唐马儒','广东东莞',2000
UNION ALL
SELECT '王尼玛',NULL,NULL SELECT * FROM @Temp ----- 查询为 NULL
SELECT * FROM @Temp WHERE [ADDRESS]=NULL --- 更改为 IS NULL ---- 查询不为 NULL
SELECT * FROM @Temp WHERE [ADDRESS]<>NULL --- 更改为 IS NOT NULL

1 IS NULL、IS NOT NULL

   平时在写 SQL 语句时,注意 = NULL、<> NULL 应为 IS NULL、IS NOT NULL,避免出现不必要错误。 

2 NULL 在聚合函数 SUM、COUNT、MAX、MIN 中处理

    在数据库中,NULL 同样作为一个值,而 NULL 值进行四则运算时, NULL+1、NULL*2诸如之类,得到最终结果都为 UNKNOW。还有 NULL >23 等比较运算时,同样得到的结果为三值逻辑中的 UNKNOW。

综上所述,SUM、MAX、MIN 三者中都包括运算比较,在运算中如果 NULL 值参与其中,最终结果将为 UNKNOW。因此,在进行 SUM、MAX、MIN 聚合时,将会舍弃 NULL 值。

而 COUNT 较为特殊, COUNT(*) 将会包含有 NULL 值行记录,COUNT(字段名) 刚将不会包含该字段含有 NULL 值行记录,而 COUNT( DISTINCT 字段名)将舍弃该字段含有 NULL 值且不重复的行记录。

 脚本 SQL  

        SELECT  *                                ,
SUM(MONEYDATA) OVER() AS '统计工资总和',
MAX(MONEYDATA) OVER() AS '工资最高金额',
COUNT(*) OVER() AS '总员工数' ,
COUNT( ADDRESS) OVER() AS '地址不为 NULL 员工数'
FROM @Temp

 3 NULL 值引发的分页问题

脚本 SQL

        --- 使用 ROW_NUMBER() 实现分页
WITH TB AS
(
SELECT * ,ROW_NUMBER() OVER( ORDER BY MONEYDATA ASC) AS ROW FROM @Temp
)
SELECT * FROM TB A WHERE A.ROW BETWEEN (2-1)*1+1 AND 2*1; --- 使用 ORDER BY 、TOP 实现分页,而在 NOT IN 中如果字段出现 NULL 值,将会出现查询未果现象
---- 因为 NOT IN 可理解为
SELECT TOP 1 * FROM @Temp
WHERE ADDRESS NOT IN ( SELECT TOP ((2-1)*1) ADDRESS FROM @Temp ORDER BY MONEYDATA ASC )
ORDER BY MONEYDATA ASC

  参考资料:https://zh.wikipedia.org/wiki/%E4%B8%89%E5%80%BC%E9%80%BB%E8%BE%91

数据库 SQL :有关 NULL 值引发 TRUE、FALSE、UNKNOW 三值逻辑的更多相关文章

  1. SQL中NULL值

    SQL的表达式,除了IS NULL和NOT NULL以外,只要出现NULL值结果都为FALSE 简单的例子: SELECT * FROM table WHERE name!='abc' 只要name值 ...

  2. SQL SERVER NULL值和连接注意问题

    联接表的列中的 null 值(如果有)互相不匹配.如果其中一个联接表的列中出现空值,只能通过外部联接返回这些空值(除非 WHERE 子句不包括空值).   下面的两个表中,每个表中要参与联接的列中均包 ...

  3. SQL Server NULL值用法及处理详解

    用法如下: 1.如果表中的某个列是可选的,那么我们可以在不向该列添加值的情况下插入新记录或更新已有的记录,这意味着该字段将以 NULL 值保存. 2.NULL 用作未知的或不适用的值的占位符. 3.定 ...

  4. 【转】Oracle索引列NULL值引发执行计划该表的测试示例

    有时开发进行表结构设计,对表字段是否为空过于随意,出现诸如id1=id2,如果允许字段为空,因为Oracle中空值并不等于空值,有可能得到意料之外的结果.除此之外,最关键的是,NULL会影响oracl ...

  5. sql 将Null 值转化成空字符串

    当Null + 任何字符串时,都等于Null. 因些用函数IsNull(字段名,''),如果字段名中的值是Null时,那么这个字段名的值是''. 例如::select code + IsNull('- ...

  6. sql处理null值

    IFNULL(expr1,expr2) 如果expr1不是NULL,IFNULL()返回expr1,否则它返回expr2.IFNULL()返回一个数字或字符串值. select (case when ...

  7. SQL之NULL值的几种处理方式

    1.创建测试表: drop table if exists tab_null_operator; create table tab_null_operator as select 1 as id,'c ...

  8. SQL NULL 值【摘自W3C】

    SQL NULL 值 本章讲解 IS NULL 和 IS NOT NULL 操作符. NULL 值是遗漏的未知数据.默认地,表的列可以存放 NULL 值. 如果表中的某个列是可选的,那么我们可以在不向 ...

  9. SQL NULL 值

    NULL 值是遗漏的未知数据. 默认地,表的列可以存放 NULL 值. 本章讲解 IS NULL 和 IS NOT NULL 操作符. SQL NULL 值 如果表中的某个列是可选的,那么我们可以在不 ...

随机推荐

  1. ArcGIS Engine栅格数据使用总结

    jojojojo2002 原文 ArcGIS Engine栅格数据使用总结 简介:ArcGIS Engine栅格数据使用总结,一个栅格数据集由一个或者多个波段(RasterBand)的数据组成,一个波 ...

  2. Java魔法类:sun.misc.Unsafe

    Unsafe类在jdk 源码的多个类中用到,这个类的提供了一些绕开JVM的更底层功能,基于它的实现可以提高效率.但是,它是一把双刃剑:正如它的名字所预示的那样,它是Unsafe的,它所分配的内存需要手 ...

  3. 【C++】统计代码覆盖率(三)

    报告集成到jenkins才是最终目的,因此又进行了部分资料查找,得到html和xml报告集成jenkins的配置如下: 一 集成html报告 这种方式集成在你已经用gcov+lcov生成了html报告 ...

  4. python27+django调用数据库

    我用的mysql版,先上无模板的版本,在views里加上 import MySQLdb 然后在下方写函数 def use_databases(request): db = MySQLdb.connec ...

  5. 一致性Hash算法在Memcached中的应用

    前言 大家应该都知道Memcached要想实现分布式只能在客户端来完成,目前比较流行的是通过一致性hash算法来实现.常规的方法是将server的hash值与server的总台数进行求余,即hash% ...

  6. 自学Java过程

    由于之前判断失误,其实也不应该说失误吧,自己脱产花了几个月来啃C,现在基本上算是啃完了吧,之所以说失误是因为:没有找到跟C有关的适合我的工作!!! 本来的打算是先把基础搞定然后去找找看有没有肯收留打杂 ...

  7. Configuring and troubleshooting a Schema Provider

    原文:https://codesmith.atlassian.net/wiki/display/Generator/Configuring+and+troubleshooting+a+Schema+P ...

  8. LeetCode Database: Rank Scores

    Write a SQL query to rank scores. If there is a tie between two scores, both should have the same ra ...

  9. spark connect to Cassandra problem

    Cassandra rowkey is Blob type, cannot select by spark. How?

  10. android开发中遇到的bug

    这种NullPointerException这么解决啊 Activity.dispatchTouchEvent 里try catch一下 参考:http://www.eoeandroid.com/th ...