📌 函数简介:MySQL 的"空值替换专家"
IFNULL() 是 MySQL 内置的一个控制流函数,它的核心功能是检查给定的值是否为NULL**,如果是,就把它替换成指定的默认值** 。
可以把它想象成一个便捷的"空值筛选器"。假设表里某个字段允许为空,在做数据展示、计算或拼接时,直接使用这个字段可能会产生不期望的 NULL 结果,比如:
- 计算销量时,因为 price 或 quantity 为 NULL,导致最终金额也变成了 NULL。
- 拼接人名时,因为 last_name 为 NULL,导致最终的字符串也变得不完整。
- 在聚合函数(如 SUM、AVG)中,NULL 值虽然通常会被忽略,但在一些复杂逻辑下依然可能导致意想不到的后果。
IFNULL() 函数就为此类问题提供了一个简单优雅的解决方案。
✍️ 语法、参数与返回值类型
IFNULL() 的语法非常简洁,只接受两个参数:
sql
IFNULL(expr1, expr2)
参数详解:
- expr1:需要判断是否为 NULL 的表达式(通常是表中的字段)。
- expr2:如果 expr1 的值为 NULL,将返回的替换值。
核心逻辑: "如果expr1 不为 NULL,函数返回expr1 ;否则返回expr2 。"
返回值类型(数据类型提升规则):
函数的返回值类型并非简单的"是 expr1 或 expr2",而是依据 expr1 和 expr2 的综合类型,按照"更通用"的原则来确定。其具体规则和优先级如下:
- 字符串 (STRING) :如果两个参数中有一个会产生字符串,则最终结果通常为字符串。
- 浮点数 (REAL/DOUBLE) :如果至少有一个参数是双精度浮点数,则结果提升为双精度浮点数。
- 定点数 (DECIMAL) :如果至少有一个参数是 DECIMAL(且没有双精度浮点数),则结果为 DECIMAL。
- 整数 (INTEGER) :
- 规则一(类型混合) :如果同时包含 UNSIGNED(无符号)和 SIGNED(有符号)整数类型,结果会提升为 SIGNED BIGINT,以防止值被意外截断。
- 规则二( UNSIGNED BIGINT 特例) :如果 expr1 是 UNSIGNED BIGINT,而 expr2 是任何其他有符号整数类型,结果会被提升为 DECIMAL(足够精度, 0),以确保能容纳所有可能的值。
因此,最佳实践是确保expr1和 expr2的数据类型一致 ,以避免因隐式类型转换导致意外的精度丢失、性能下降甚至查询错误。
🧪 基础示例:从简单用法开始
✅ 基本用法示例
sql
--检查字符串是否为NULL
SELECT IFNULL('Hello', 'Default'); --返回'Hello'(因为'Hello'不是NULL)
--检查第一个参数是否为NULL
SELECT IFNULL(NULL, 'Default'); --返回'Default'(因为NULL被替换)