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;
只要 price 或 discount 其中一个是 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 里乱用,容易干掉索引