SQL:MySQL函数:空值处理函数(NULL Handling Functions)

目录

什么是空值(NULL)?

常用空值处理函数总览

1️⃣ IFNULL() – 空值替换函数(If Null)

2️⃣ COALESCE() – 多参数空值判断(返回第一个非 NULL 值)

3️⃣ NULLIF() – 相等则返回 NULL(避免错误值)

4️⃣ IS NULL / IS NOT NULL – 判断是否为空

使用场景总结


什么是空值(NULL)?

在 MySQL 中,NULL 表示一个“未知”或“无值”的状态,不是数字 0,也不是空字符串 ''。在处理数据库数据时,我们经常会遇到字段值为 NULL 的情况,这时就需要使用空值处理函数来避免出错。

详细介绍可以看我之前发表的文章:

SQL易错解析:你真的理解 NULL 吗?_sql null-CSDN博客

常用空值处理函数总览

函数名称(英文)中文名称基本语法英文含义含义说明
IFNULL()空值替换函数IFNULL(expr1, expr2)If Null如果 expr1 是 NULL,则返回 expr2,否则返回 expr1
COALESCE()多值优先返回非空值COALESCE(val1, val2, ..., valN)Coalesce(联合)从左到右返回第一个非 NULL 的值
NULLIF()相等则返回 NULLNULLIF(expr1, expr2)Null If Equal如果两个参数相等,则返回 NULL,否则返回第一个参数
IS NULL / IS NOT NULL空值判断expr IS NULL / expr IS NOT NULLIs Null判断一个表达式是否为 NULL,返回布尔值(1/0)

1️⃣ IFNULL() – 空值替换函数(If Null)

  • 英文名称:IFNULL — If Null

  • 中文含义:如果表达式为 NULL,则返回指定的默认值

  • 语法:

IFNULL(expr1, expr2)
  • 解释:常用于处理查询结果中的空值,用默认值替代。

  • 示例:

SELECT name, IFNULL(bonus, 0) AS bonus_value FROM employees;

2️⃣ COALESCE() – 多参数空值判断(返回第一个非 NULL 值)

  • 英文名称:COALESCE — Coalesce (联合、合并)

  • 中文含义:从多个参数中返回第一个非 NULL 的值

  • 语法:

COALESCE(val1, val2, ..., valN)
  • 解释:相比 IFNULL 更灵活,可以处理多个参数,按顺序判断非 NULL。

  • 示例:

SELECT COALESCE(phone, email, '无联系方式') AS contact FROM users;

3️⃣ NULLIF() – 相等则返回 NULL(避免错误值)

  • 英文名称:NULLIF — Null If Equal

  • 中文含义:如果两个表达式相等,返回 NULL;否则返回第一个表达式

  • 语法:

NULLIF(expr1, expr2)
  • 解释:常用于除法操作中,避免除以 0 错误。

  • 示例:

SELECT total / NULLIF(quantity, 0) AS avg_price FROM sales;

4️⃣ IS NULL / IS NOT NULL – 判断是否为空

  • 英文名称:IS NULL — Is Null

  • 中文含义:判断某个值是否为 NULL(或不为 NULL)

  • 语法:

column_name IS NULL
column_name IS NOT NULL
  • 解释:常用于 WHERE 子句中进行空值筛选。

  • 示例:

SELECT * FROM employees WHERE bonus IS NULL;

使用场景总结

应用场景推荐函数示例语句
替换空值为默认值IFNULL()IFNULL(bonus, 0)
多个字段找非空值COALESCE()COALESCE(phone, email)
避免除以 0 错误NULLIF()amount / NULLIF(quantity, 0)
查询空值记录IS NULLWHERE address IS NULL
查询非空值记录IS NOT NULLWHERE birthday IS NOT NULL
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值