如何在查询中处理空值_mysql null判断方法

发布时间 - 2026-01-29 00:00:00    点击率:
MySQL 中 NULL 表示未知或不存在,须用 IS NULL/IS NOT NULL 判断;= 或 != 与 NULL 比较恒为 UNKNOWN;可用 COALESCE/IFNULL 转换默认值;聚合函数自动忽略 NULL,索引中 NULL 单独存储。

在 MySQL 中,空值(NULL)不是空字符串('')也不是数字 0,而是一个特殊的标记,表示“未知”或“不存在”。直接用 =!= 判断 NULL 会返回 FALSE 或 UNKNOWN,因此必须使用专门的 NULL 判断语法。

用 IS NULL 和 IS NOT NULL 判断空值

这是最标准、最安全的方式。MySQL 提供了两个专用操作符:

  • column_name IS NULL:匹配该字段值为 NULL 的记录
  • column_name IS NOT NULL:匹配该字段值非 NULL 的记录

例如查询没有填写电话号码的用户:

SELECT * FROM users WHERE phone IS NULL;

避免用 = NULL 或 != NULL

以下写法**永远不生效**,因为 NULL 参与任

何普通比较运算都会返回 UNKNOWN(在 WHERE 中等价于 FALSE):

  • WHERE phone = NULL → 不会查出任何 NULL 记录
  • WHERE phone != NULLWHERE phone NULL → 同样无效

MySQL 会警告你:“Incorrect usage of NULL value”,但不会报错,容易埋下逻辑漏洞。

用 COALESCE 或 IFNULL 处理 NULL 显示或计算

当需要把 NULL 转成默认值(比如显示为 '暂无' 或参与数值计算),可用:

  • COALESCE(col, '默认值'):返回第一个非 NULL 的表达式,支持多个参数
  • IFNULL(col, '默认值'):仅接受两个参数,更简洁

示例:把 NULL 的 age 显示为 0,用于统计平均年龄:

SELECT AVG(IFNULL(age, 0)) FROM users;

注意 NULL 在聚合函数和索引中的行为

大多数聚合函数(如 COUNT、SUM、AVG)会自动忽略 NULL 值:

  • COUNT(*) 统计所有行;COUNT(col) 只统计 col 非 NULL 的行
  • 索引列允许存储 NULL(除非定义了 NOT NULL 约束),但 B-Tree 索引中 NULL 值通常单独存放,部分场景下可能影响查询效率

建表时若业务上该字段不应为空,建议显式声明 NOT NULL 并设默认值,从源头减少 NULL 处理负担。


# mysql  # 聚合函数  # NULL  # count  # select  # 字符串  # 默认值  # 这是  # 暂无  # 第一个  # 多个  # 不存在  # 不应  # 报错  # 但不  # 转成 


相关栏目: 【 网站优化151355 】 【 网络推广146373 】 【 网络技术251813 】 【 AI营销90571


相关推荐: Laravel怎么实现搜索高亮功能_Laravel结合Scout与Algolia全文检索【实战】  利用python获取某年中每个月的第一天和最后一天  免费视频制作网站,更新又快又好的免费电影网站?  详解Android——蓝牙技术 带你实现终端间数据传输  美食网站链接制作教程视频,哪个教做美食的网站比较专业点?  如何用AI一键生成爆款短视频文案?小红书AI文案写作指令【教程】  如何在橙子建站上传落地页?操作指南详解  如何自己制作一个网站链接,如何制作一个企业网站,建设网站的基本步骤有哪些?  Laravel如何自定义错误页面(404, 500)?(代码示例)  高性能网站服务器配置指南:安全稳定与高效建站核心方案  网站制作软件有哪些,制图软件有哪些?  如何用腾讯建站主机快速创建免费网站?  Laravel怎么导出Excel文件_Laravel Excel插件使用教程  百度输入法全感官ai怎么关 百度输入法全感官皮肤关闭  香港代理服务器配置指南:高匿IP选择、跨境加速与SEO优化技巧  Linux系统运维自动化项目教程_Ansible批量管理实战  php结合redis实现高并发下的抢购、秒杀功能的实例  Linux虚拟化技术教程_KVMQEMU虚拟机安装与调优  jQuery 常见小例汇总  ai格式如何转html_将AI设计稿转换为HTML页面流程【页面】  学生网站制作软件,一个12岁的学生写小说,应该去什么样的网站?  Laravel集合Collection怎么用_Laravel集合常用函数详解  详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)  Microsoft Edge如何解决网页加载问题 Edge浏览器加载问题修复  Laravel如何构建RESTful API_Laravel标准化API接口开发指南  如何快速查询域名建站关键信息?  JS中对数组元素进行增删改移的方法总结  微信小程序制作网站有哪些,微信小程序需要做网站吗?  Laravel怎么清理缓存_Laravel optimize clear命令详解  如何用景安虚拟主机手机版绑定域名建站?  JavaScript中如何操作剪贴板_ClipboardAPI怎么用  js实现获取鼠标当前的位置  如何快速建站并高效导出源代码?  在线制作视频的网站有哪些,电脑如何制作视频短片?  桂林网站制作公司有哪些,桂林马拉松怎么报名?  Laravel如何自定义分页视图?(Pagination示例)  微信小程序 HTTPS报错整理常见问题及解决方案  清除minerd进程的简单方法  PHP正则匹配日期和时间(时间戳转换)的实例代码  大连企业网站制作公司,大连2025企业社保缴费网上缴费流程?  Laravel怎么判断请求类型_Laravel Request isMethod用法  如何在云服务器上快速搭建个人网站?  javascript中对象的定义、使用以及对象和原型链操作小结  PHP 500报错的快速解决方法  阿里云网站搭建费用解析:服务器价格与建站成本优化指南  制作ppt免费网站有哪些,有哪些比较好的ppt模板下载网站?  WEB开发之注册页面验证码倒计时代码的实现  android nfc常用标签读取总结  javascript中的数组方法有哪些_如何利用数组方法简化数据处理  动图在线制作网站有哪些,滑动动图图集怎么做?