查看: 76|回覆: 0

MySQL COALESCE函数使用方法示例详解

[複製鏈接]

5

主題

0

回帖

0

積分

热心网友

金币
0
閲讀權限
220
精華
0
威望
0
贡献
0
在線時間
0 小時
註冊時間
2010-4-30
發表於 2025-12-23 09:26:11 | 顯示全部樓層 |閲讀模式

前言

COALESCE 是 MySQL 中一个非常有用的函数,用于返回参数列表中的第一个非 NULL 值。下面详细介绍它的用法和示例。

基本语法

COALESCE(value1, value2, ..., valueN)

功能说明

  • 函数从左到右依次检查每个参数
  • 返回第一个不为 NULL 的参数值
  • 如果所有参数都为 NULL,则返回 NULL

使用场景

1. 处理 NULL 值替代

SELECT COALESCE(column_name, '默认值') FROM table_name;

当 column_name 为 NULL 时,返回 ‘默认值’

2. 多列优先选择

SELECT COALESCE(phone, mobile, email, '无联系方式') AS contact_info FROM customers;

按优先级选择第一个不为 NULL 的联系方式

3. 计算中使用

SELECT product_name, price * COALESCE(discount, 1) AS final_price FROM products;

当 discount 为 NULL 时使用 1 作为默认折扣

实际示例

示例1:基本使用

SELECT COALESCE(NULL, 'A', 'B');  -- 返回 'A'
SELECT COALESCE(NULL, NULL, 'B'); -- 返回 'B'
SELECT COALESCE(NULL, NULL, NULL); -- 返回 NULL

示例2:表数据应用

-- 假设有员工表 employees,其中 commission 列可能为 NULL
SELECT 
    employee_name,
    COALESCE(commission, 0) AS commission
FROM 
    employees;

示例3:与 CASE 表达式等效

COALESCE 可以看作是以下 CASE 表达式的简写:

CASE 
    WHEN value1 IS NOT NULL THEN value1
    WHEN value2 IS NOT NULL THEN value2
    ...
    ELSE NULL
END

注意事项

  1. COALESCE 是 ANSI SQL 标准函数,在大多数数据库中可用
  2. IFNULL 函数不同,COALESCE 可以接受多个参数
  3. 性能考虑:参数越多,评估成本越高
  4. 所有参数应该是相同或兼容的数据类型

与相关函数比较

  • IFNULL(expr1, expr2):只有两个参数,相当于 COALESCE(expr1, expr2)
  • ISNULL(expr):只检查是否为 NULL,返回 1 或 0
  • NULLIF(expr1, expr2):当 expr1 = expr2 时返回 NULL,否则返回 expr1

COALESCE 因其灵活性和标准性,通常是处理 NULL 值的最佳选择。

总结

回覆

使用道具 舉報

您需要登錄後才可以回帖 登錄 | 立即注册

本版積分規則

相关侵权、举报、投诉及建议等,请发 E-mail:qiongdian@foxmail.com

Powered by Discuz! X5.0 © 2001-2026 Discuz! Team.

在本版发帖返回顶部