mysql casewhen用法
时间: 2023-10-28 07:55:13 浏览: 85
MySQL中的CASE WHEN语句是用于执行条件语句的一种方式。它类似于其他编程语言中的if-else语句。它可以根据条件执行不同的操作,语法如下:
CASE
WHEN condition1 THEN result1
WHEN condition2 THEN result2
...
ELSE resultN
END
其中,condition1、condition2等是条件表达式,result1、result2等是根据条件表达式的结果返回的值。ELSE子句是可选的,如果没有匹配的条件则返回ELSE子句中的值。
相关问题
mysql casewhen
MySQL中的CASE WHEN语句是一种条件判断语句,它可以根据满足的条件执行不同的操作。当满足某个条件时,该条件下的代码块会被执行,并且后续的条件不再考虑。CASE WHEN语句可以用于SELECT语句中的列值替换、WHERE子句中的条件判断和GROUP BY子句中的分组排序。
例如,以下是一个使用CASE WHEN语句的示例:
SELECT CASE WHEN parent_id < 3 THEN '<3'
WHEN parent_id >= 3 AND parent_id < 5 THEN '>=3 && <5'
ELSE '>=5'
END AS parent_id_new,
count(*) AS num_count,
parent_id,
type_id,
type_name
FROM tdb_goods_types
GROUP BY parent_id_new
ORDER BY num_count;
在上述示例中,根据parent_id的不同取值,使用CASE WHEN语句将parent_id分为三个不同的区间,并将其分组为parent_id_new。然后,统计每个分组中的记录数,并按照记录数进行排序。最终的查询结果包含parent_id_new、num_count、parent_id、type_id和type_name这些列的值。<span class="em">1</span><span class="em">2</span><span class="em">3</span>
#### 引用[.reference_title]
- *1* [mysql中case when的用法](https://blog.csdn.net/u010147215/article/details/124529659)[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: 50%"]
- *2* *3* [MySQL 的CASE WHEN 语句使用说明](https://blog.csdn.net/lkx021699/article/details/120543003)[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: 50%"]
[ .reference_list ]
mysql中casewhen用法
CASE WHEN是MySQL中的条件表达式,用于根据条件返回不同的结果。
它的基本语法如下:
```
CASE
WHEN condition1 THEN result1
WHEN condition2 THEN result2
...
ELSE result
END
```
其中,condition1、condition2等是条件表达式,result1、result2等是对应条件为真时返回的结果。ELSE子句是可选的,用于指定当条件都不满足时的默认返回结果。
下面是一个示例:
```
SELECT name,
CASE
WHEN score >= 90 THEN '优秀'
WHEN score >= 80 THEN '良好'
WHEN score >= 70 THEN '中等'
ELSE '不及格'
END AS grade
FROM students;
```
这个示例中,根据学生的分数(score)判断其等级(grade),并将结果作为一个新的列返回。根据不同的分数范围,返回不同的等级。
希望对你有所帮助!如果还有其他问题,请继续提问。
阅读全文