SQL之CASE WHEN用法详解

14 篇文章 10 订阅
文章介绍了SQL中CASE函数的两种形式——简单Case函数和Case搜索函数,以及它们在不同场景下的应用,如根据分数判断等级,统计男女学生及格人数,和在WHERE子句中进行条件过滤。同时,文章强调了CASE函数的注意事项,如返回值类型一致和处理NULL的方法。
摘要由CSDN通过智能技术生成

前言

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

THEN后边的值与ELSE后边的值类型应一致,否则会报错。如下:

CASE SCORE WHEN 'A' THEN '优' ELSE 0 END

'优’和0数据类型不一致则报错:

[Err] ORA-00932: 数据类型不一致: 应为 CHAR, 但却获得 NUMBER

下面介绍几种常用场景。

场景1:有分数score,score<60返回不及格,score>=60返回及格,score>=80返回优秀

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

注意:如果你想判断score是否null的情况,WHEN score = null THEN ‘缺席考试’,这是一种错误的写法,正确的写法应为:

CASE WHEN score IS NULL THEN '缺席考试' ELSE '正常' END

场景2:现老师要统计班中,有多少男同学,多少女同学,并统计男同学中有几人及格,女同学中有几人及格,要求用一个SQL输出结果。

表结构如下:其中STU_SEX字段,0表示男生,1表示女生。

STU_CODESTU_NAMESTU_SEXSTU_SCORE
XM小明088
XL小磊055
XF小峰045
XH小红166
XN晓妮177
XY小伊199
SELECT 
	SUM (CASE WHEN STU_SEX = 0 THEN 1 ELSE 0 END) AS MALE_COUNT,
	SUM (CASE WHEN STU_SEX = 1 THEN 1 ELSE 0 END) AS FEMALE_COUNT,
	SUM (CASE WHEN STU_SCORE >= 60 AND STU_SEX = 0 THEN 1 ELSE 0 END) AS MALE_PASS,
	SUM (CASE WHEN STU_SCORE >= 60 AND STU_SEX = 1 THEN 1 ELSE 0 END) AS FEMALE_PASS
FROM 
	THTF_STUDENTS

输出结果如下:

MALE_COUNTFEMALE_COUNTMALE_PASSFEMALE_PASS
3313

场景3:CASE 语句放在 WHERE 子句中进行条件过滤

  • 在 SQL 中,CASE 语句不能直接放在 WHERE 子句中进行条件过滤,因为 CASE 语句是用来处理选择逻辑的,而不是用来过滤行的。

  • 如果你想根据条件筛选行,可以使用 CASE 语句生成一个虚拟列,然后在 WHERE 子句中过滤这个虚拟列的值。以下是一个示例:

SELECT *
FROM your_table
WHERE
  (CASE
    WHEN ton > 1000 THEN
      CASE
        WHEN ton / 1000 > 12 THEN '大于12'
        ELSE '不大于12'
      END
    ELSE
      CASE
        WHEN ton > 12 THEN '大于12'
        ELSE '不大于12'
      END
  END) = '大于12';
  • 在这个示例中,CASE 语句生成了一个名为 result 的虚拟列,然后在 WHERE 子句中筛选出 result 列的值为 ‘大于12’ 的行。这样就可以根据条件判断筛选出符合要求的行了。

请注意,这种方法会增加查询的复杂度,特别是对于大型数据集。确保你的数据库和查询逻辑能够处理这种额外的计算。


总结

如果此篇文章有帮助到您, 希望打大佬们能关注点赞收藏评论支持一波,非常感谢大家!
如果有不对的地方请指正!!!

参考1

  • 3
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
在使用CASE WHEN语句时,可以根据不同的条件执行不同的操作。以下是一个case when用法练习题的示例: 假设我们有一个表格table_name,其中包含三列a、b和c。请问如何使用CASE WHEN语句来比较这三列的大小,并将较大的值作为结果输出? 可以使用以下语句来实现: SELECT (CASE WHEN a>b AND a>c THEN a WHEN b>c THEN b ELSE c END) AS max_value FROM table_name; 上述语句中,我们使用了CASE WHEN来比较a、b和c的大小。如果a最大,则输出a的值;如果b最大,则输出b的值;否则,输出c的值。我们使用了AND运算符来同时比较a>b和a>c的情况。最终,我们将结果命名为max_value。 请注意,这只是一个练习题的示例,实际使用时,你需要根据具体的业务需求来编写CASE WHEN语句。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* [【MySQLSQLCASE WHEN用法详解](https://blog.csdn.net/qq_43718048/article/details/127277369)[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_1"}}] [.reference_item style="max-width: 50%"] - *3* [MySQL- Case When 用法](https://blog.csdn.net/weixin_42514750/article/details/114342009)[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_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

lfwh

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值