数据库中的COALESCE函数用于返回参数列表中第一个非NULL值,若所有参数均为NULL则返回NULL

Oracle/MySQL/SQLServer/Postgres/openGauss等关系型数据库中的COALESCE函数用于返回参数列表中第一个非NULL值,若所有参数均为NULL则返回NULL。

1、基本语法

sql 复制代码
COALESCE(expr1, expr2, ..., exprn),支持任意数量参数。
  • 从左到右依次判断 value1, value2, value3, ...
  • 返回 第一个不是 NULL 的值
  • 所有都为 NULL,则返回 NULL

2、 典型应用场景包括‌:

2.1、示例1

  • 给字段设置显示默认值
sql 复制代码
SELECT COALESCE(nick_name, real_name, '匿名用户') AS display_name
FROM users;

含义:

  • 如果 nick_name 不为 NULL → 用 nick_name
  • 否则如果 real_name 不为 NULL → 用 real_name
  • 否则用 '匿名用户'

2.2、 避免聚合结果为 NULL

sql 复制代码
SELECT COALESCE(SUM(amount), 0) AS total_amount
FROM orders
WHERE user_id = 123;

如果这个用户没有订单,SUM(amount) 为 NULL,使用 COALESCE 返回 0。

2.3、构造带默认值的查询条件或字段

sql 复制代码
SELECT COALESCE(phone, '无手机号') AS phone_display
FROM customers;

3、和 NVL / IFNULL 的对比

  • COALESCE:标准 SQL,支持多个参数,很多数据库(PostgreSQL/openGauss/GaussDB、MySQL、Oracle 等)都支持
  • NVL(expr1, expr2)(Oracle):只支持两个参数,相当于 COALESCE(expr1, expr2)
  • IFNULL(expr1, expr2)(MySQL):也只支持两个参数

4、小注意点

所有参数的数据类型要能相互兼容,否则会报类型错误

在 WHERE 里用时,只是返回值,不会"忽略 NULL 行",要配合条件使用,例如:

sql 复制代码
SELECT *
FROM users
WHERE COALESCE(status, 'inactive') = 'active';

5、gaussdb中使用COALESCE

sql 复制代码
-- ============================================
-- 1. 函数测试
-- ============================================
-- 创建函数:计算用户总消费
CREATE OR REPLACE FUNCTION test_schema.get_user_total_spent(p_user_id INT)
RETURNS DECIMAL(10, 2) AS $$
DECLARE
    v_total DECIMAL(10, 2);
BEGIN
    SELECT COALESCE(SUM(total_amount), 0) INTO v_total
    FROM test_schema.tb_orders
    WHERE user_id = p_user_id AND order_status = 'completed';
    
    RETURN v_total;
END;
$$ LANGUAGE plpgsql;

-- 测试函数
SELECT test_schema.get_user_total_spent(1) AS user1_total_spent;
sql 复制代码
-- ============================================
-- 2. 视图测试
-- ============================================
-- 创建视图
CREATE OR REPLACE VIEW test_schema.v_user_order_summary AS
SELECT 
    u.user_id,
    u.username,
    u.email,
    COUNT(o.order_id) AS total_orders,
    COALESCE(SUM(CASE WHEN o.order_status = 'completed' THEN o.total_amount ELSE 0 END), 0) AS completed_amount,
    COALESCE(SUM(CASE WHEN o.order_status = 'pending' THEN o.total_amount ELSE 0 END), 0) AS pending_amount
FROM test_schema.tb_users u
LEFT JOIN test_schema.tb_orders o ON u.user_id = o.user_id
GROUP BY u.user_id, u.username, u.email;

-- 查询视图
SELECT * FROM test_schema.v_user_order_summary ORDER BY completed_amount DESC;
相关推荐
Nandeska9 小时前
15、基于MySQL的组复制
数据库·mysql
AllData公司负责人10 小时前
AllData数据中台-数据同步平台【Seatunnel-Web】整库同步MySQL同步Doris能力演示
大数据·数据库·mysql·开源
加油,小猿猿10 小时前
Java开发日志-双数据库事务问题
java·开发语言·数据库
山岚的运维笔记11 小时前
SQL Server笔记 -- 第20章:TRY/CATCH
java·数据库·笔记·sql·microsoft·sqlserver
Gain_chance11 小时前
33-学习笔记尚硅谷数仓搭建-DWS层交易域用户粒度订单表分析及设计代码
数据库·数据仓库·hive·笔记·学习·datagrip
未来之窗软件服务11 小时前
计算机等级考试—高频英语词汇—东方仙盟练气期
数据库·计算机软考·东方仙盟
lekami_兰11 小时前
MySQL 长事务:藏在业务里的性能 “隐形杀手”
数据库·mysql·go·长事务
蚕豆哥11 小时前
【2026马年重启】我的 Primavera P6/Unifier 技术笔记,继续更新!
ai·oracle·项目管理·unifier·p6·进度管理·甲骨文
JQLvopkk11 小时前
C# 轻量级工业温湿度监控系统(含数据库与源码)
开发语言·数据库·c#
devmoon13 小时前
在 Polkadot Runtime 中添加多个 Pallet 实例实战指南
java·开发语言·数据库·web3·区块链·波卡