【SQL|大数据|数据清洗|过滤】where条件中 “ != “ 和 “ NOT IN() ” 对NULL的处理

对数据进行清洗过滤的时候,NULL往往是一个很特殊的存在,对NULL值的存在通常有以下三种方式

1、保留NULL

2、过滤掉NULL

3、将NULL替换为其他符合业务需求的默认常量

下面是一些常用处理NULL的方式:

如下图所示数据源:

car_vin:汽车车架号,汽车的唯一标识

id:汽车检测里程的id,每次检测的唯一标识

mileage:汽车的行驶里程

sql 复制代码
SELECT * FROM tmp;

一、WHERE

这部分讲解在WHERE子句中如何对NULL值进行处理

1、IS NULL 、IS NOT NULL

sql 复制代码
SELECT  car_vin
        ,id
        ,mileage
FROM    tmp
WHERE   mileage IS NOT NULL
;
sql 复制代码
SELECT  car_vin
        ,id
        ,mileage
FROM    tmp
WHERE   mileage IS NULL
;

2、!=

在where子句中用到!=号,后面接过滤条件,此时NULL值也会被过滤

sql 复制代码
SELECT  car_vin
        ,id
        ,mileage
FROM    tmp
WHERE   mileage !=0
;

从下图的结果可以看出,除了0值,NULL同样被过滤掉了

由于 NULL 的特殊性质,在 SQL 中,任何与 NULL 进行比较的结果都是 NULL。这意味着在条件 mileage != 0 中,如果 mileage 是 NULL,这个表达式的结果不会返回 true,而是返回 NULL。where子句中只返回结果为true的行,因此,该行记录不会被选中,即NULL值会被过滤掉。

WHERE mileage !=0 只会返回 mileage 不为 0 的记录,但也会排除掉 mileage 为 NULL 的记录。因此,mileage 为 NULL 的行不会出现在查询结果中。

3、NOT IN

使用 NOT IN 同样会过滤掉NULL值

sql 复制代码
SELECT  car_vin
        ,id
        ,mileage
FROM    tmp
WHERE   mileage NOT IN (0)
;

在 SQL 中,任何与 NULL 进行比较的结果都是 NULL
SELECT NULL NOT IN (0); 返回的结果依旧为NULL

所以使用NOT IN ,NULL值所在的行不满足返回结果为TRUE的条件,会被过滤掉。

二、函数

1、NVL()

当您在查询中希望用一个具体的值来代替NULL值时,使用NVL函数可将NULL值替换为指定的值,确保在执行数据分析或生成报告时,结果中不会有意外的空值。

命令格式

sql 复制代码
nvl(T <value>, T <default_value>)

参数说明

value:必填。输入参数。T指代输入数据类型,可以是当前使用的数据库或计算引擎支持的所有数据类型。

default_value:必填。替换后的值。必须与value的数据类型保持一致。

返回值说明

如果value值为NULL,返回default_value,否则返回value,函数的两个参数的数据类型必须一致。

相关推荐
qq_463944863 分钟前
【Spark征服之路-2.3-Spark运行架构】
大数据·架构·spark
长河14 分钟前
Flink 重启后事件被重复消费的原因与解决方案
大数据·flink
TDengine (老段)15 分钟前
TDengine 替换 Hadoop,彻底解决数据丢失问题 !
大数据·数据库·hadoop·物联网·时序数据库·tdengine·涛思数据
南棱笑笑生17 分钟前
20250605使用boot-repair来恢复WIN10和ubuntu22.04.6双系统的启动
数据库·postgresql
初次见面我叫泰隆28 分钟前
Redis——1、服务端高并发分布式结构演进之路
数据库·redis·分布式
立控信息(lkone)1 小时前
库室联管联控系统
大数据·安全
2401_876907521 小时前
IEC 61347-1:2015 灯控制装置安全标准详解
大数据·数据结构·人工智能·算法·安全·学习方法
朝九晚五ฺ1 小时前
【MySQL基础】数据库的备份与还原
数据库·mysql·oracle
R²AIN SUITE1 小时前
大量企业系统超龄服役!R²AIN SUITE 一体化企业提效解决方案重构零售数智化基因
大数据·重构·零售
kuankeTech1 小时前
从“人找政策”到“政策找人”:智能退税ERP数字化重构外贸生态
大数据·人工智能·物联网·软件开发·erp