SQL 中的 IFNULL 函数是什么?

IFNULL 是 SQL 里一个用来处理 NULL 值 的函数,作用很简单:

如果字段值是 NULL,就返回一个指定的默认值;否则返回原值。

一句话:给 NULL 找个"兜底值"


基本语法

sql 复制代码
IFNULL(expr1, expr2)

含义:

  • expr1:要判断的字段或表达式
  • expr2:当 expr1 为 NULL 时返回的值

判断规则只有一个:

  • expr1 IS NULL → 返回 expr2
  • 否则 → 返回 expr1

最常见的使用场景

1️⃣ 查询结果中避免出现 NULL

sql 复制代码
SELECT IFNULL(name, '未知') FROM user;

如果 name 是 NULL,查询结果会显示为 未知,而不是 NULL。


2️⃣ 数值计算时防止结果为 NULL

这是最容易踩坑的地方。

sql 复制代码
SELECT price + discount FROM orders;

只要 pricediscount 其中一个是 NULL,结果就是 NULL

正确写法:

sql 复制代码
SELECT IFNULL(price, 0) + IFNULL(discount, 0) FROM orders;

3️⃣ 聚合函数后的兜底处理

比如某个条件下没有数据时:

sql 复制代码
SELECT IFNULL(SUM(amount), 0) FROM orders WHERE status = 'paid';

否则 SUM 没有数据时返回的是 NULL,不是 0。


IFNULL ≠ 判断"空字符串"

⚠️ 重点容易误解的地方:

  • NULL''(空字符串)不是一回事
  • IFNULL 只判断 NULL
sql 复制代码
IFNULL('', '默认值')  -- 返回 '',不会返回默认值

如果你想同时处理空字符串,需要配合其他函数,比如:

sql 复制代码
IFNULL(NULLIF(name, ''), '默认值')

和 COALESCE 有什么区别?

  • IFNULL(a, b)只支持 2 个参数
  • COALESCE(a, b, c, ...):支持多个参数,返回第一个非 NULL 的
sql 复制代码
COALESCE(col1, col2, col3, 0)

在 MySQL 中:

  • 简单场景 → IFNULL 更直观
  • 复杂兜底链 → COALESCE 更合适

性能和索引注意事项

⚠️ 在 WHERE 条件 中这样写:

sql 复制代码
WHERE IFNULL(status, 0) = 1

可能会导致 索引失效

更好的写法是:

sql 复制代码
WHERE status = 1 OR status IS NULL

这是实战里很常见的坑。


总结一句话

  • IFNULL 是 查 NULL 的,不是查空值的
  • 常用于 展示兜底、计算防 NULL、聚合结果处理
  • WHERE 里乱用,容易干掉索引
相关推荐
Σίσυφος190015 分钟前
PCL法向量估计 之 方向约束法向量(Orientation Guided Normal)
数据库
老毛肚18 分钟前
手写mybatis
java·数据库·mybatis
海山数据库24 分钟前
移动云大云海山数据库(He3DB)postgresql_anonymizer插件原理介绍与安装
数据库·he3db·大云海山数据库·移动云数据库
l1t24 分钟前
DeepSeek总结的PostgreSQL的GPT推理SQL移植到DuckDB的性能优化方法
sql·gpt·postgresql
云飞云共享云桌面27 分钟前
高性能图形工作站的资源如何共享给10个SolidWorks研发设计用
linux·运维·服务器·前端·网络·数据库·人工智能
2501_9279935335 分钟前
SQL Server 2022安装详细教程(图文详解,非常详细)
数据库·sqlserver
星火s漫天36 分钟前
第一篇: 使用Docker部署flask项目(Flask + DB 容器化)
数据库·docker·flask
xcLeigh41 分钟前
Python 项目实战:用 Flask 实现 MySQL 数据库增删改查 API
数据库·python·mysql·flask·教程·python3
威迪斯特42 分钟前
Flask:轻量级Web框架的技术本质与工程实践
前端·数据库·后端·python·flask·开发框架·核心架构
xu_yule44 分钟前
Redis存储(15)Redis的应用_分布式锁_Lua脚本/Redlock算法
数据库·redis·分布式