SQL 中 CASE WHEN 及 SELECT CASE WHEN 的用法

SQL 中 CASE WHEN 及 SELECT CASE WHEN 的用法

CASE WHEN 是 SQL 中非常实用的条件表达式,它允许你在查询中实现条件逻辑。以下是详细的用法说明:

1. 基本语法结构

sql 复制代码
CASE 
    WHEN condition1 THEN result1
    WHEN condition2 THEN result2
    ...
    ELSE default_result
END

或者简单形式:

sql 复制代码
CASE expression 
    WHEN value1 THEN result1
    WHEN value2 THEN result2
    ...
    ELSE default_result
END

2. 在 SELECT 语句中的用法

示例1:简单条件判断

sql 复制代码
SELECT 
    employee_name,
    salary,
    CASE 
        WHEN salary > 10000 THEN '高薪'
        WHEN salary > 5000 THEN '中等'
        ELSE '一般'
    END AS salary_level
FROM employees;

示例2:等值比较(简单形式)

sql 复制代码
SELECT 
    product_name,
    CASE category_id
        WHEN 1 THEN '电子产品'
        WHEN 2 THEN '服装'
        WHEN 3 THEN '食品'
        ELSE '其他'
    END AS category_name
FROM products;

3. 在 UPDATE 语句中的用法

sql 复制代码
UPDATE orders
SET discount = 
    CASE 
        WHEN order_amount > 1000 THEN 0.1
        WHEN order_amount > 500 THEN 0.05
        ELSE 0
    END;

4. 在 ORDER BY 中的用法

sql 复制代码
SELECT * FROM customers
ORDER BY 
    CASE 
        WHEN country = 'China' THEN 1
        WHEN country = 'USA' THEN 2
        ELSE 3
    END;

5. 在 GROUP BY 中的用法

sql 复制代码
SELECT 
    CASE 
        WHEN age < 20 THEN '青少年'
        WHEN age BETWEEN 20 AND 30 THEN '青年'
        ELSE '成年'
    END AS age_group,
    COUNT(*) AS count
FROM users
GROUP BY age_group;

6. 嵌套 CASE WHEN 用法

sql 复制代码
SELECT 
    student_name,
    score,
    CASE 
        WHEN score >= 90 THEN 'A'
        WHEN score >= 80 THEN 
            CASE 
                WHEN attendance_rate > 0.9 THEN 'B+'
                ELSE 'B'
            END
        WHEN score >= 70 THEN 'C'
        ELSE 'D'
    END AS grade
FROM students;

7. 在聚合函数中使用

sql 复制代码
SELECT 
    department_id,
    SUM(CASE WHEN gender = 'M' THEN 1 ELSE 0 END) AS male_count,
    SUM(CASE WHEN gender = 'F' THEN 1 ELSE 0 END) AS female_count
FROM employees
GROUP BY department_id;

注意事项

  1. CASE WHEN 会按顺序判断条件,第一个满足的条件会被执行,后面的条件将被忽略
  2. 如果没有条件满足且没有 ELSE 子句,结果将为 NULL
  3. 所有 THEN 子句返回的数据类型应该兼容
  4. 在复杂的 CASE 表达式中,适当使用括号可以提高可读性

CASE WHEN 是 SQL 中非常强大的条件表达式,掌握它可以让你写出更加灵活和强大的查询语句。

相关推荐
dreams_dream2 小时前
Django的Settings 配置文件详解
数据库·django·sqlite
一只叫煤球的猫2 小时前
看到同事设计的表结构我人麻了!聊聊怎么更好去设计数据库表
后端·mysql·面试
遇见你的雩风3 小时前
【MySQL】CRUD基础详解
数据库·mysql
夜雨听萧瑟5 小时前
sqlite创建数据库,创建表,插入数据,查询数据的C++ demo
数据库·sqlite
.Shu.6 小时前
Mysql InnoDB 底层架构设计、功能、原理、源码系列合集【四、事务引擎核心 - MVCC与锁机制】
数据库·mysql
多工坊6 小时前
【DataGrip】连接达梦数据库后,能查询数据但是看不到表的几种情况分析,达梦数据库驱动包下载DmJdbcDriver18.jar
java·数据库·jar
何中应7 小时前
如何用Redis作为消息队列
数据库·redis·缓存
liulilittle7 小时前
.NET反射与IL反编译核心技术
开发语言·数据库·c#·.net·反射·反编译·il
老纪的技术唠嗑局7 小时前
向量数据库在 UGC 社区个性化推荐的落地指南
数据库
张鱼小丸子7 小时前
MySQL企业级部署与高可用实战
运维·数据库·mysql·云原生·高可用·mha·组从复制