使用case when进行排序

前段时间遇到一个特殊排序要求:
1.将类型为史学类(4)或者为文学类(3)的展示到前面;
2.不是这两个类型的,要按照创建时间排序。

这时候就用到了case when了
以下是我的写法。
在这里插入图片描述
可以很明显的看到 4和3都排序在前面其余的按照创建时间倒序排序。

接下来我们就说说 case when的用法:

CASE WHEN条件表达式函数:类似JAVA中的IF ELSE语句。
格式:

CASE WHEN condition THEN result
 [WHEN...THEN...]
 ELSE result
 END

其中:
condition是一个返回布尔类型的表达式,如果表达式返回true,则整个函数返回相应result的值,如果表达式皆为false,则返回ElSE后result的值,如果省略了ELSE子句,则返回NULL。

我们介绍几种应用场景:
1.有分数表score_table,其中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
    SCORE_TABLE

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

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

2.有项目表PROJECT_TABLE,状态(STATUS)分为以下几种:草稿1、已发布2、已下架3、删除4。现在想要展示已经发布的项目展示在最上面,然后是草稿、已下架、已删除状态的项目。

select 
    id, name, subject_type_required, created_time
from PROJECT_TABLE 
order by case status 
when 2 then 1
when 1 then 2
when 3 then 3
when 4 then 4
end

3.现老师要统计班中,有多少男同学,多少女同学,并统计男同学中有几人及格,女同学中有几人及格,要求用一个SQL输出结果。
表结构如下:其中STU_SEX字段,0表示男生,1表示女生。
在这里插入图片描述

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

输出结果:
在这里插入图片描述

CASE WHEN 函数使用起来简单易懂,此文章只作了简单的使用介绍。还需要根据实际业务场景灵活使用

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值