SQL语句的case用法
时间: 2023-09-22 10:09:35 浏览: 118
SQL语句中的CASE表达式用于根据特定条件对数据进行条件判断和处理。它可以在SELECT、WHERE、ORDER BY等子句中使用。以下是CASE表达式的一般语法:
```
CASE
WHEN condition1 THEN result1
WHEN condition2 THEN result2
...
ELSE result
END
```
其中,condition1、condition2等是条件表达式,result1、result2等是对应条件满足时的结果。ELSE子句是可选的,用于指定当所有条件都不满足时的默认结果。
例如,假设我们有一个名为"orders"的表,其中包含"order_id"和"order_total"两列。我们可以使用CASE表达式将订单总额进行分类:
```
SELECT order_id, order_total,
CASE
WHEN order_total > 1000 THEN 'High'
WHEN order_total > 500 THEN 'Medium'
ELSE 'Low'
END AS order_category
FROM orders;
```
上述例子中,如果订单总额大于1000,则分类为"High";如果大于500,则分类为"Medium";否则分类为"Low"。使用CASE表达式,我们可以根据不同的条件给数据赋予不同的值。
相关问题
sql语句case when用法
CASE WHEN 是 SQL 语言中的条件表达式,它可以用于 SELECT、WHERE 和 ORDER BY 等语句中,用于根据条件对结果进行控制。其基本语法如下:
```
CASE
WHEN condition1 THEN result1
WHEN condition2 THEN result2
...
ELSE default_result
END
```
其中,`condition1`、`condition2` 等是条件表达式,`result1`、`result2` 等是对应的结果表达式,`default_result` 是当所有条件都不满足时的默认结果。
下面通过一个简单的示例来说明 CASE WHEN 的用法。假设我们有一个员工表(employee),其中包含员工姓名(name)、所属部门(department)和薪水(salary)等字段。我们想要查询出每个部门的平均薪水,并按照薪水从高到低排序,可以使用如下语句:
```
SELECT
department,
AVG(salary) AS avg_salary,
CASE
WHEN AVG(salary) >= 5000 THEN '高薪部门'
WHEN AVG(salary) >= 3000 THEN '中薪部门'
ELSE '低薪部门'
END AS salary_level
FROM
employee
GROUP BY
department
ORDER BY
avg_salary DESC;
```
在这个示例中,我们使用了 CASE WHEN 表达式来根据平均薪水的大小,将部门分为高薪、中薪和低薪三个等级,并将结果存储在一个名为 `salary_level` 的新列中。
sql语句case when
SQL语句中的CASE WHEN是一种条件表达式函数,用于根据给定的条件返回不同的结果值。它的语法可以有多种形式。其中一种形式是使用CASE WHEN语句来进行多条件判断。例如,可以使用CASE WHEN来根据学生的分数判断其等级,如下所示:
CASE WHEN SCORE = 'A' THEN '优'
WHEN SCORE = 'B' THEN '良'
WHEN SCORE = 'C' THEN '中'
ELSE '不及格'
END
上述代码中,如果分数等于'A',则返回'优',如果分数等于'B'则返回'良',如果分数等于'C'则返回'中',否则返回'不及格'。注意,所有返回值的类型应该一致,否则会报错。
另一种形式是使用简化的CASE WHEN语句,如下所示:
CASE SCORE
WHEN 'A' THEN '优'
ELSE '不及格'
END
这种形式的CASE WHEN语句与上述代码的效果是相同的,根据分数判断返回不同的结果值。同样,返回值的类型应一致。
除了上述例子中直接判断分数的情况,还可以在SELECT语句中使用CASE WHEN来进行条件判断,并在结果集中返回对应的备注。例如:
SELECT STUDENT_NAME,
(CASE WHEN score < 60 THEN '不及格'
WHEN score >= 60 AND score < 80 THEN '及格'
WHEN score >= 80 THEN '优秀'
ELSE '异常'
END) AS REMARK
FROM TABLE
上述代码中,根据不同的分数范围,返回相应的备注值。如果分数小于60,则返回'不及格',如果分数大于等于60且小于80,则返回'及格',如果分数大于等于80,则返回'优秀',否则返回'异常'。
需要注意的是,如果想要判断分数是否为null的情况,不能使用WHEN score = null的写法,而应该使用IS NULL来判断。例如,当score为null时,可以使用WHEN score IS NULL THEN '缺席考试'来判断。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* *2* *3* [sql case when的用法(转)](https://blog.csdn.net/weixin_43955984/article/details/101000234)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 100%"]
[ .reference_list ]
阅读全文