IS NULL 是唯一可靠判断字段是否为 NULL 的方式,因 NULL 表示未知,不能用 = 或 != 比较;IS NOT NULL 仅排除 NULL,不保证内容有效;NULL、''、0、FALSE 语义完全不同,需严格区分。IS NULL 判断字段是否为 NULL 值IS NULL 是 SQL 中唯一可靠判断字段值是否为 NULL 的方式。因为 NULL 表示"未知",不是值,所以不能用 = 或 != 比较------column = NULL 永远返回 UNKNOWN(在 WHERE 中等价于 FALSE),查不到任何结果。用 WHERE column IS NULL 才能命中真正为 NULL 的行 WHERE column = '' 只匹配空字符串,和 NULL 完全无关 字符串、数字、日期字段都适用,语法一致,不因类型变化 在索引列上使用 IS NULL 通常能走索引(取决于数据库和索引定义,MySQL 5.7+、PostgreSQL、SQL Server 均支持) SELECT * FROM users WHERE email IS NULL;IS NOT NULL 排除 NULL 值但不等于"有内容"IS NOT NULL 筛出非 NULL 的行,但它不保证字段有意义:空字符串 ''、全空格、零值 0、默认时间 '0001-01-01' 都算"非 NULL",但业务上可能仍是无效数据。若需排除"空内容",得组合判断,比如:WHERE email IS NOT NULL AND TRIM(email) != '' NOT (column IS NULL) 语义等价,但可读性差,不推荐 某些 ORM(如 Django ORM)生成的 __isnull=False 底层就是 IS NOT NULL,要注意它不自动过滤空字符串 PostgreSQL 对 IS NOT NULL 优化较好;MySQL 在 MyISAM 引擎下对 IS NOT NULL 的索引使用略保守(InnoDB 无此问题)别把 NULL 和空字符串、零值混为一谈这是最常踩的坑:数据库里 NULL、''、0、FALSE 是四个独立状态,语义完全不同。 通义听悟 阿里云通义听悟是聚焦音视频内容的工作学习AI助手,依托大模型,帮助用户记录、整理和分析音视频内容,体验用大模型做音视频笔记、整理会议记录。
相关推荐
曲幽1 小时前
别再用网页翻译看源码了!你的私人翻译神器LibreTranslate,部署避坑指南来了用户556918817533 小时前
#从脚本到独立程序:Python + Playwright 批量抓取的完整踩坑记录倔强的石头_4 小时前
KingbaseES 新版MySQL 兼容版体验:旧版迁移 + 功能实测兵慌码乱17 小时前
基于 MediaPipe 与 PySide2 的手势交互音乐控制系统实现:轻量化视觉交互全流程解析luckdewei19 小时前
FastAPI 资产管理系统实战:复杂 ORM 关联、Alembic 迁移与 N+1 查询优化aqi001 天前
15天学会AI应用开发(八)使用向量数据库实现RAG功能Csvn1 天前
`functools.lru_cache` —— 一行代码搞定缓存加速金銀銅鐵2 天前
[Python] 从《千字文》中随机挑选汉字cup112 天前
[技术复盘] Windows Python 打包实战:Nuitka 环境踩坑总结与 CI 自动化构建全指南