理解case when then else end 的使用,基础概念,建表语句,用例讲解

一、基础概念

  • case :表示需要处理的字段
  • when :表示条件
  • then :表示当when执行为true时,再执行的语句
  • else :表示当所有的when执行为false时,再执行的语句
  • end:表示 case 语句结束的结尾

二、建表语句


SET NAMES utf8mb4;
SET FOREIGN_KEY_CHECKS = 0;

-- ----------------------------
-- Table structure for student
-- ----------------------------
DROP TABLE IF EXISTS `student`;
CREATE TABLE `student`  (
  `name` varchar(20) CHARACTER SET utf8mb4 COLLATE utf8mb4_0900_ai_ci NULL DEFAULT NULL COMMENT '名字',
  `sex` int(11) NULL DEFAULT NULL COMMENT '性别,1表示为男,2表示女',
  `core` int(11) NULL DEFAULT NULL COMMENT '分数'
) ENGINE = InnoDB CHARACTER SET = utf8mb4 COLLATE = utf8mb4_0900_ai_ci ROW_FORMAT = Dynamic;

-- ----------------------------
-- Records of student
-- ----------------------------
INSERT INTO `student` VALUES ('张三', 1, 50);
INSERT INTO `student` VALUES ('李四', 2, 60);
INSERT INTO `student` VALUES ('王五', 2, 90);
INSERT INTO `student` VALUES ('赵六', 1, 70);

SET FOREIGN_KEY_CHECKS = 1;
  • 图形化表格
    在这里插入图片描述

三、用例讲解

  1. 执行sql语句
SELECT (CASE WHEN a.`name`='张三' THEN a.core ELSE 0 END) AS '分数' FROM student a ;
  • 结果
    在这里插入图片描述

  • 讲解:进行匹配的是名字name,首先匹配第一行,name是等于张三,所以返回core也就是50。后面的记录名字都不是 ‘张三’ ,所以执行else。其实case的本质就是通过逻辑判定生成一个新的字段,该字段可以通过as 取名。

  • 相同结果的sql语句,大家可以试着执行一遍,写法不同,思考逻辑一样

SELECT (CASE a.`name` WHEN '张三' THEN a.core ELSE 0 END) AS '分数' FROM student a ;
# 看着END后面连接了一个“分数”,但是其实这个“分数”和END之间是省略了AS,大家不要理解错了。CASE语句执行到END逻辑处理就已经结束了
SELECT CASE a.`name` WHEN '张三' THEN a.core ELSE 0 END '分数'  FROM student a ;
  1. 执行一列里面进行多次匹配
SELECT (CASE WHEN a.`name`='张三' THEN a.core WHEN a.`name`='李四' THEN a.core END) AS '分数' FROM student a ;
  • 结果
    在这里插入图片描述

  • 讲解:进行匹配的是名字name ,当第一个WHEN 通过的时候 ,这条记录直接执行第一个THEN 不会进入到第二个WHEN。当第一个WHEN 没通过的时候,才会进入到WHEN,多个WHEN的sql语句原理一样。和java中的 swich case 有异曲同工之妙。

  • 验证当第一个 WHEN 通过不执行第二个WHEN的sql例子

SELECT (CASE WHEN a.`name`='张三' THEN a.core WHEN a.`name`='张三' THEN 100 END) AS '分数' FROM student a ;
  • 结果
    在这里插入图片描述
  • 分析,如果会执行第二个WHEN 的话,第一条记录得到的值应该为100,而不是50。
  1. 多列的匹配
SELECT (CASE WHEN a.`name`='张三' THEN a.core END) AS '张三',(CASE WHEN a.`name`='李四' THEN a.core END) AS '李四' FROM student a ;
  • 结果
    在这里插入图片描述
  1. 更新case使用
UPDATE student a
SET a.sex = CASE a.sex
WHEN 1 THEN
    11
WHEN 2 THEN
    22
ELSE a.sex
END
  • 结果更新每行sex 中的1变成11,2变成22。
    在这里插入图片描述
    在这里插入图片描述

参考文档

### SQL 中 `CASE WHEN THEN ELSE END` 和 `HAVING` 子句的用法 #### 使用 `CASE WHEN THEN ELSE END` 在SQL查询中,`CASE WHEN THEN ELSE END` 是一种用于实现条件逻辑的强大工具。此结构允许基于不同条件返回不同的值[^2]。 如,在统计学生选课数量和总成绩时可以使用 `CASE WHEN THEN ELSE END` 来处理可能存在的空值情况: ```sql SELECT a.s_id, a.s_name, COUNT(b.c_id), SUM(CASE WHEN b.s_score IS NOT NULL THEN b.s_score ELSE 0 END) AS total_score FROM student AS a LEFT JOIN score AS b ON a.s_id = b.s_id GROUP BY a.s_id, a.s_name; ``` 这段代码通过 `CASE WHEN THEN ELSE END` 结构来确保当分数为空时不计入总分计算之中[^3]。 #### 使用 `HAVING` 子句 `HAVING` 子句通常与聚合函数一起使用,用来过滤由 `GROUP BY` 创的结果集中的记录组。它类似于 `WHERE` 子句,但是作用于已经完成分组的数据上。 考虑这样一个场景:想要找出至少选择了两门课程的学生及其平均成绩超过85分的情况,则可以在上述基础上加入 `HAVING` 进行筛选: ```sql SELECT a.s_id, a.s_name, COUNT(b.c_id) AS course_count, AVG(CASE WHEN b.s_score IS NOT NULL THEN b.s_score ELSE 0 END) AS avg_score FROM student AS a LEFT JOIN score AS b ON a.s_id = b.s_id GROUP BY a.s_id, a.s_name HAVING COUNT(b.c_id) >= 2 AND AVG(CASE WHEN b.s_score IS NOT NULL THEN b.s_score ELSE 0 END) > 85; ``` 这里不仅应用了 `CASE WHEN THEN ELSE END` 处理潜在缺失数据的问题,还利用 `HAVING` 对最终结果进行了进一步限定。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值