当前位置: 首页 > article >正文

解析 SQL 中的 NULL 与比较操作:NULL 值与任何值的比较会返回 UNKNOWN

在 SQL 查询中,我们经常会遇到 NULL 值。NULL 值的行为与其他数据类型的值是不同的,尤其是在进行条件比较时。NULL 与其他值的比较结果是什么?

1. NULL 的特殊性:三值逻辑

首先,我们需要理解 SQL 中的三值逻辑(Three-Valued Logic)。与传统的布尔逻辑不同,SQL 处理 NULL 值时引入了一个额外的 “未知” 状态。SQL 中的三值逻辑有三种可能的结果:

  • TRUE(真)
  • FALSE(假)
  • UNKNOWN(未知)

这三种结果在 SQL 查询的执行中会产生不同的行为,尤其是在 WHERE 子句中的条件判断时。如果一个表达式的结果为 UNKNOWN,该行数据将被视为“不符合条件”,因此不会被选中。

2. NULL 与其他值比较时的行为

我们以这个例子来分析一下:

appCode IS NULL AND appCode != 'app_yyy'

这个条件看起来好像是在做一个简单的 NULL 检查和不等于 'app_yyy' 的判断。但是在 SQL 中,NULL 的比较并不是简单的。具体来说:

  • appCode IS NULL 用来检查 appCode 是否为 NULL,如果是 NULL,结果为 TRUE,否则为 FALSE
  • appCode != 'app_yyy' 用来判断 appCode 是否不等于 'app_yyy'。但是在 SQL 中,任何与 NULL 进行的比较都会返回 UNKNOWN,因为 NULL 代表的是“未知”的状态。换句话说,NULL != 'app_yyy' 的结果是 UNKNOWN,而不是 TRUEFALSE

3. SQL 中的 NULL 比较规则

SQL 的比较规则如下:

  • NULL 与任何非 NULL 值进行比较(例如 NULL = 'some_value'NULL != 'some_value')结果是 UNKNOWN
  • NULLNULL 的比较(例如 NULL = NULL)也返回 UNKNOWN,而不是 TRUE
  • 只有明确使用 IS NULLIS NOT NULL 来检查 NULL

所以,回到例子,appCode IS NULL 结果为 TRUE 时,appCode != 'app_yyy' 的结果是 UNKNOWN,这会使得整个条件变成 TRUE AND UNKNOWN。由于 AND 操作符中,TRUE AND UNKNOWN 的结果是 UNKNOWN,因此该行记录不会被选中。


http://www.kler.cn/a/468336.html

相关文章:

  • Java最新面试题(全网最全、最细、附答案)
  • 【微服务与K8S】
  • QPainter,QPen,QBrush详解
  • 6miu盘搜的使用方法
  • 78、使用爱芯派2_AX630C开发板 3.2T高有效算力 低功耗 支持AI-ISP真黑光实验
  • 【three.js】场景搭建
  • Visual Studio C++使用笔记
  • 【数学建模笔记】评价模型-基于熵权法的TOPSIS模型
  • PyTorch通过搭建LSTM网络,对MNIST手写数字数据集进行了训练和评估,实现了对手写数字的分类功能
  • 生成模型的现状2025年的新兴趋势
  • 手机投屏到电视的3种选择:无线本地投屏,无线远程投屏,AirPlay投屏
  • 设计模式 结构型 享元模式(Flyweight Pattern)与 常见技术框架应用 解析
  • np.ndarray 是 NumPy 库中的核心数据结构
  • 雅思真题短语梳理(三十五)
  • 决策树(二)属性选择度量之基尼系数详细讲解
  • lec7-路由与路由器
  • 《ROS2 机器人开发 从入门道实践》 鱼香ROS2——第5章内容
  • 弹性云服务器ECS“规格”
  • Vue3中使用 Vue Flow 流程图方法
  • [2个简单方法]如何将iPhone中的联系人保存到iCloud?
  • 联邦学习的 AI 大模型微调中,加性、选择性、重参数化和混合微调
  • Android设备使用AOA协议进行主机与配件模式通信
  • 深入理解连接池:从数据库到HTTP的优化之道
  • maven之插件调试
  • C++ 设计模式:迭代器模式(Iterator Pattern)
  • TCP Analysis Flags 之 TCP Retransmission