SQL 里 Case When 怎么用

2025-01-15 02:29:02   小编

SQL里Case When怎么用

在SQL的世界中,Case When语句是一个强大且灵活的工具,它允许我们在查询中进行条件判断,就像编程语言里的if-else语句一样,为数据处理带来了极大的便利。

Case When语句有两种基本形式:简单Case语句和搜索Case语句。

简单Case语句的语法结构相对直观:

CASE column_name
    WHEN value1 THEN result1
    WHEN value2 THEN result2
    ELSE result_else
END

这种形式主要用于对某一列的值进行简单的匹配判断。例如,我们有一个存储学生成绩的表 students,其中有一列 grade 表示成绩等级。现在我们想将这些等级转换为对应的分数范围。可以使用以下查询:

SELECT
    student_name,
    CASE grade
        WHEN 'A' THEN '90 - 100'
        WHEN 'B' THEN '80 - 89'
        WHEN 'C' THEN '70 - 79'
        ELSE '60 - 69'
    END AS score_range
FROM
    students;

搜索Case语句则更为灵活,它可以基于更复杂的条件进行判断:

CASE
    WHEN condition1 THEN result1
    WHEN condition2 THEN result2
    ELSE result_else
END

假设我们还是在 students 表中,想要根据学生的总分来划分等级。总分大于等于 90 分为 优秀,80 到 89 分为 良好,70 到 79 分为 中等,其他为 及格。查询语句如下:

SELECT
    student_name,
    total_score,
    CASE
        WHEN total_score >= 90 THEN '优秀'
        WHEN total_score >= 80 AND total_score < 90 THEN '良好'
        WHEN total_score >= 70 AND total_score < 80 THEN '中等'
        ELSE '及格'
    END AS grade_level
FROM
    students;

Case When语句不仅可以用于查询结果的输出,还能在 UPDATE 语句中根据条件更新数据。比如我们要根据学生的成绩调整他们的奖学金状态:

UPDATE students
SET scholarship_status =
    CASE
        WHEN total_score >= 90 THEN '全额奖学金'
        WHEN total_score >= 80 THEN '半额奖学金'
        ELSE '无奖学金'
    END;

掌握SQL里的Case When语句,能让我们在处理数据时更加得心应手,无论是数据查询、数据更新还是复杂的数据转换,它都能发挥重要作用。通过合理运用,能大大提升我们对数据库的操作效率和数据处理能力。

TAGS: 数据库操作 SQL语句 SQL技巧 SQL_Case_When

欢迎使用万千站长工具!

Welcome to www.zzTool.com