SQL CASE语法

SQL CASE表达式详解
SQL CASE 表达式是一种通用的条件表达式,类似于其它语言中的 if/else 语句。

CASE WHEN condition THEN result [WHEN ...] [ELSE result] END
CASE 子句可以用于任何表达式可以有效存在的地方。 condition 是一个返回boolean 的表达式。 如果结果为真,那么 CASE 表达式的结果就是符合条件的 result。如果结果为假,那么以相同方式搜寻任何随后的 WHEN 子句。 如果没有 WHEN condition 为真,那么 case 表达式的结果就是在 ELSE 子句里的值。 如果省略了 ELSE 子句而且没有匹配的条件, 结果为 NULL。


Case具有两种格式。简单Case函数和Case搜索函数。

--简单Case函数

CASE sex

WHEN '1' THEN '男'

WHEN '2' THEN '女'

ELSE '其他' END

--Case搜索函数

CASE WHEN sex = '1' THEN '男'

WHEN sex = '2' THEN '女'

ELSE '其他' END


这两种方式,可以实现相同的功能。简单Case函数的写法相对比较简洁,但是和Case搜索函数相比,功能方面会有些限制,比如写判断式。
还有一个需要注意的问题,Case函数只返回第一个符合条件的值,剩下的Case部分将会被自动忽略。

--比如说,下面这段SQL,你永远无法得到“第二类”这个结果

CASE WHEN col_1 IN ( 'a', 'b') THEN '第一类'

WHEN col_1 IN ('a') THEN '第二类'

ELSE'其他' END


示例
A. 使用带有简单 CASE 函数的 SELECT 语句
在 SELECT 语句中,简单 CASE 函数仅检查是否相等,而不进行其他比较。以下示例使用 CASE 函数更改产品系列类别的显示,以使这些类别更易理解。

复制代码
USE AdventureWorks;
GO
SELECT ProductNumber, Category =
CASE ProductLine
WHEN 'R' THEN 'Road'
WHEN 'M' THEN 'Mountain'
WHEN 'T' THEN 'Touring'
WHEN 'S' THEN 'Other sale items'
ELSE 'Not for sale'
END,
Name
FROM Production.Product
ORDER BY ProductNumber;
GO


B. 使用带有简单 CASE 函数和 CASE 搜索函数的 SELECT 语句
在 SELECT 语句中,CASE 搜索函数允许根据比较值在结果集内对值进行替换。下面的示例根据产品的价格范围将标价显示为文本注释。

复制代码
USE AdventureWorks;
GO
SELECT ProductNumber, Name, 'Price Range' =
CASE
WHEN ListPrice = 0 THEN 'Mfg item - not for resale'
WHEN ListPrice < 50 THEN 'Under $50'
WHEN ListPrice >= 50 and ListPrice < 250 THEN 'Under $250'
WHEN ListPrice >= 250 and ListPrice < 1000 THEN 'Under $1000'
ELSE 'Over $1000'
END
FROM Production.Product
ORDER BY ProductNumber ;
GO
SQL中,`CASE THEN`语句是一种条件表达式,用于根据不同条件选择不同的结果。它类似于其他编程语言中的 `if...then...else` 结构,并且可以灵活地嵌套使用以处理复杂情况。`CASE` 语句可以在 `SELECT`、`WHERE` 和 `ORDER BY` 子句中使用[^2]。 ### 基本语法 SQL 中的 `CASE` 表达式的基本语法如下: ```sql CASE WHEN condition1 THEN result1 WHEN condition2 THEN result2 ... ELSE default_result END ``` 在这个语法结构中,首先使用 `CASE` 关键字开始表达式,然后列出多个 `WHEN` 子句,每个子句包含一个条件和一个对应的结果。最后可以选择性地使用 `ELSE` 子句指定默认结果。当某个 `WHEN` 条件为真时,将返回对应的 `THEN` 结果;如果所有条件都不满足,则返回 `ELSE` 中的结果(如果未提供 `ELSE`,则返回 `NULL`)[^3]。 ### 使用示例 以下是一个常见用例:根据学生的分数划分等级。 ```sql SELECT student_name, CASE WHEN score >= 90 THEN '优秀' WHEN score >= 80 THEN '良好' WHEN score >= 70 THEN '一般' ELSE '不及格' END AS grade FROM students; ``` 在此查询中,`CASE` 表达式根据 `score` 字段值的范围返回相应的成绩等级,并将其作为新列 `grade` 返回。如果分数大于等于 90,则返回 `'优秀'`;如果分数在 80 到 89 之间,则返回 `'良好'`;如果分数在 70 到 79 之间,则返回 `'一般'`;否则返回 `'不及格'`[^3]。 ### 进阶应用 除了基本的条件判断外,`CASE` 表达式还可以与其他 SQL 函数结合使用,例如聚合函数或字符串函数,以实现更复杂的逻辑。以下是一个在 `WHERE` 子句中动态筛选数据的例子: ```sql SELECT * FROM orders WHERE CASE WHEN order_status = 'completed' THEN order_date > DATE_SUB(CURDATE(), INTERVAL 30 DAY) ELSE order_date > DATE_SUB(CURDATE(), INTERVAL 7 DAY) END; ``` 该查询根据订单状态 (`order_status`) 动态调整筛选条件:已完成的订单要求最近 30 天内创建,而未完成的订单只需最近 7 天内的记录[^2]。 ### 嵌套使用 `CASE` 表达式支持嵌套,允许在一个 `WHEN` 或 `ELSE` 分支中再次使用 `CASE`。例如: ```sql SELECT product_name, CASE WHEN category = 'Electronics' THEN CASE WHEN price > 1000 THEN '高端电子产品' ELSE '普通电子产品' END WHEN category = 'Clothing' THEN CASE WHEN price > 200 THEN '高端服装' ELSE '普通服装' END ELSE '其他类别商品' END AS product_type FROM products; ``` 此查询通过嵌套的 `CASE` 表达式进一步细化了商品分类,根据不同类别和价格区间对产品进行详细归类[^1]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值