mysql casewhen 多条件判断
时间: 2023-11-06 12:08:01 浏览: 306
可以使用MySQL的CASE WHEN语句进行多条件判断,示例如下:
```
SELECT column1, column2,
CASE
WHEN condition1 THEN result1
WHEN condition2 THEN result2
ELSE default_result
END AS new_column
FROM table_name;
```
其中,condition1和condition2是多个条件,result1和result2是对应条件的结果,default_result是当所有条件都不满足时的默认结果。
例如,以下语句将根据不同的分数段给学生打上不同的等级:
```
SELECT name, score,
CASE
WHEN score >= 90 THEN 'A'
WHEN score >= 80 THEN 'B'
WHEN score >= 70 THEN 'C'
ELSE 'D'
END AS grade
FROM student;
```
相关问题
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嵌套
在MySQL中,可以使用CASE WHEN语句进行条件判断和嵌套。嵌套CASE WHEN语句的基本语法如下:
```
CASE
WHEN condition1 THEN result1
WHEN condition2 THEN result2
...
ELSE result
END
```
可以在WHEN子句中继续嵌套CASE WHEN语句,以实现更复杂的条件判断。
以下是一个嵌套CASE WHEN语句的示例,假设我们有一个名为`products`的表,其中包含`product_id`、`product_name`和`price`字段,我们想根据价格将产品分为三个等级:高级、中级和低级。
```sql
SELECT
product_id,
product_name,
CASE
WHEN price > 100 THEN '高级'
WHEN price > 50 THEN '中级'
ELSE '低级'
END AS product_level
FROM
products;
```
在上面的示例中,我们根据价格使用嵌套的CASE WHEN语句将产品分为不同的等级。如果价格大于100,则产品被标记为'高级';如果价格在50和100之间,则产品被标记为'中级';否则,产品被标记为'低级'。
阅读全文