为什么 SQL 中 NULL 不能用 = 比较:三值逻辑与查询陷阱
副标题 / 摘要 在 SQL 中,NULL 代表“未知”,因此 = 比较不会返回 true。本文解释三值逻辑的机制,并给出正确写法。 目标读者 经常写 SQL 的后端工程师 在查询结果上踩过 NULL 坑的开发者 需要制定查询规范的团队 背景 / 动机 很多人会写: SELECT * FROM t WHERE field = NULL; 然后发现它“不起作用”。原因是 SQL 使用三值逻辑,NULL 不等于任何值(包括 NULL 本身)。 核心概念 NULL 表示未知,不是空字符串或 0 三值逻辑:true / false / unknown 正确判断方式:IS NULL / IS NOT NULL 实践指南 / 步骤 判断 NULL 用 IS NULL 不要用 = 与 NULL 比较 需要替代值时用 COALESCE 对外部输入做明确转换 可运行示例 SELECT id FROM users WHERE deleted_at IS NULL; 使用替代值: SELECT COALESCE(age, 0) FROM users; 解释与原理 NULL = NULL 的结果是 unknown,而不是 true。 SQL 的 WHERE 只保留 true 的行,unknown 会被过滤掉,因此查询为空。 ...