MYSQL Case When搜索查询

Case When可以用作select语句中的搜索,如果满足条件,就给字段附上结果值。

语法:

CASE WHEN '表达式1' THEN '结果1' 
     WHEN '表达式2' THEN '结果2'
     WHEN '表达式3' THEN '结果3'
     ELSE '其他结果'
END

简单的例子:

当学生表tb_student里,gender=“1”,性别字段为“男”,gender=“0”,性别字段为“女”。

SELECT 
	stu_code AS '学号',
	stu_name AS '学生姓名',
	(CASE 
		WHEN gender=1 THEN '男'
	    WHEN gender=0 THEN '女'
	    ELSE '未知'
	END) AS '性别',
	grade AS '分数'
FROM tb_student;

通过sum函数汇总

举个例子,通过计算gender字段满足不同条件的累加值,计算男生人数和女生人数。

SELECT 
	dep_code AS '部门编号',
	(CASE 
		WHEN dep_code=10 THEN '总经办'
		WHEN dep_code=11 THEN '财务'
		WHEN dep_code=12 THEN '技术'
		WHEN dep_code=13 THEN '测试'
		WHEN dep_code=14 THEN '运维'
		ELSE '其他'
	END) AS '部门',
    SUM((CASE WHEN gender = 1 THEN 1 ELSE 0 END)) AS '男生人数',
    SUM((CASE WHEN gender = 0 THEN 1 ELSE 0 END)) AS '女生人数',
    COUNT(*) AS '部门总人数'
FROM
    tb_employee
GROUP BY dep_code;

参考博文

https://blog.csdn.net/Alian_1223/article/details/128253574

  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

打赏作者

阿达斯加

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

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

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

打赏作者

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

抵扣说明:

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

余额充值