【问题处理】—— SQL里进行 null值 的判断永远返回 false?

简介: 【问题处理】—— SQL里进行 null值 的判断永远返回 false?

项目场景:

一个SQL查询的数据条目少了,本来应该有6条数据,但现在只有5条


问题描述

一个SQL查询的数据条目少了,本来应该有6条数据,但现在只有五条

SELECT
    intent.business_date,
    intent.intent_id,
    detail.approve_status
  FROM
    intention intent
    LEFT JOIN approvedetail detail ON intent.intent_id = detail.intent_id 
 where 
    detail.approve_status != '4' ;

本身是个非常简单的左连接查询,但是只查出来5条

而主表有6条数据

SELECT
    intent.business_date,
    intent.intent_id
  FROM
    intention intent;


原因分析:

因为我们只用了一个where条件,所以问题肯定在这里,那是不是approvedetail 里有等于4的数据,所以被过滤掉了呢?我们来看这张表的数据

select intent_id, approve_status from oapprovedetail ;


1d679212a0a446caa3ac3a22feed6bfe.png

可以看到有五条数据,但里面并没有状态为‘4’的行。那么从逻辑上说,左表不应该被过滤,应该是6条数据啊,也就是说预想中的查询数据应该如下,第6行数据approve_status应该为null,而不是整行被过滤掉


此刻,心里隐隐有了推测。会不会是null值的判断有问题?其实这个问题很早有听闻过,但是时间太长没什么印象了。说的就是在sql 里对 null 进行值的判断得到的都是false,即使你的判断是 (null != ‘4’)这种不等于判断

那么我们接下来直接开始印证这个结论

SELECT 
  CASE WHEN
    ( NULL != '4' ) 
  THEN
      1 ELSE 2 
  END AS 'res' ;

d3a414e3cc7148f3ac4910943a4859f9.png

果然出来的结果是2 ,也就是说 ( NULL != ‘4’ ) 在数据库里的判断是 false, 上述结论是在mysql 里是这样的,oracle 呢?我们也可以试一下


SELECT 
  CASE WHEN
    ( NULL != '4' ) 
  THEN
      1 ELSE 2 
  END AS res from dual;

oracle 里的结果也是2

后面,我又调换等于号两边,对 ( ‘4’ != null)进行了判断,结果还是2。那么看来这个逻辑主要就是涉及 null 值的判断 都会返回 false 了


解决方案:

知道了问题的原因,如果想查出第6行数据,那就只能针对这种特殊情况做补丁了,最后的结果是

SELECT
    intent.business_date,
    intent.intent_id,
    detail.approve_status
  FROM
    intention intent
    LEFT JOIN approvedetail detail ON intent.intent_id = detail.intent_id 
 where 
    detail.approve_status != '4' or detail.approve_status is null;

最后结果符合预期

目录
相关文章
|
5月前
|
SQL 数据库
SQL 中的 NULL 值:定义、测试和处理空数据,以及 SQL UPDATE 语句的使用
NULL 值是指字段没有值的情况。如果表中的字段是可选的,那么可以插入新记录或更新记录而不向该字段添加值。此时,该字段将保存为 NULL 值。需要注意的是,NULL 值与零值或包含空格的字段不同。具有 NULL 值的字段是在记录创建期间留空的字段。
59 0
|
5月前
|
SQL 关系型数据库 MySQL
我使用flinkcdc的sql形式进行全量同步,4张表,有两张表数据没进去,看日志,id怎么是null呢?
我使用flinkcdc的sql形式进行全量同步,4张表,有两张表数据没进去,看日志,id怎么是null呢?
117 40
|
4月前
|
JSON PHP 数据格式
php 删掉空的数组 json数据. 空数据(false 0 ““ null)
php 删掉空的数组 json数据. 空数据(false 0 ““ null)
php 删掉空的数组 json数据. 空数据(false 0 ““ null)
|
5月前
|
JavaScript 前端开发
JavaScript快速删除对象数组中某一个指定元素。注意:是对象数组,如果是数值数组,请慎用!会伤及无辜0、false、英文空格、undefined、null。
JavaScript快速删除对象数组中某一个指定元素。注意:是对象数组,如果是数值数组,请慎用!会伤及无辜0、false、英文空格、undefined、null。
|
6月前
|
安全 关系型数据库 MySQL
java.sql.SQLException: null,message server: Host ora-rac2 is blocked because of many
java.sql.SQLException: null,message server: Host ora-rac2 is blocked because of many
|
6月前
|
SQL 关系型数据库 数据库
DB2 SQL Error: SQLCODE=-302, SQLSTATE=22001, SQLERRMC=null
DB2 SQL Error: SQLCODE=-302, SQLSTATE=22001, SQLERRMC=null
131 0
|
8月前
|
SQL 数据采集 测试技术
软件测试|SQL中的null值,该如何理解?
软件测试|SQL中的null值,该如何理解?
246 0
|
10月前
|
PHP
php开发实战分析(3):php中判断变量为空(0、false、null)的方法
php开发实战分析(3):php中判断变量为空(0、false、null)的方法
169 0
|
10月前
|
SQL 关系型数据库 MySQL
SQL聚合函数SUM值为NULL引发的爆炸
在写这篇文章之前,最想提醒大家的是,开发一定不能想当然,看着没问题就不调试了,结果它就是有问题的。如果时间很紧,到了测试阶段才发现问题解决问题那就很狼狈很被动了,不要问我为什么会特别想提这个。
94 0
SQL聚合函数SUM值为NULL引发的爆炸
|
3月前
|
机器学习/深度学习 SQL 关系型数据库
【MySQL进阶之路丨第十一篇】一文带你精通MySQL NULL值处理、正则表达式
【MySQL进阶之路丨第十一篇】一文带你精通MySQL NULL值处理、正则表达式
38 0