• 理解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
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 9
    • 10
    • 11
    • 12
    • 13
    • 14
    • 15
    • 16
    • 17
    • 18
    • 19
    • 20
    • 21
    • 22
    • 23
    • 图形化表格
      在这里插入图片描述

    三、用例讲解

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

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

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

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

    • 讲解:进行匹配的是名字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 ;
    
    • 1
    • 结果
      在这里插入图片描述
    • 分析,如果会执行第二个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
    • 结果
      在这里插入图片描述
    1. 更新case使用
    UPDATE student a
    SET a.sex = CASE a.sex
    WHEN 1 THEN
        11
    WHEN 2 THEN
        22
    ELSE a.sex
    END
    
    • 1
    • 2
    • 3
    • 4
    • 5
    • 6
    • 7
    • 8
    • 结果更新每行sex 中的1变成11,2变成22。
      在这里插入图片描述
      在这里插入图片描述

    参考文档

  • 相关阅读:
    logback.xml日志输出原理分析
    DAOS学习笔记及思考
    【LeetCode热题100】打卡第14天:下一个排列&最长有效括号
    uiautomator2的安装,使用,在浏览器中查看页面的信息,简单快捷的ui测试工具,app测试工具(一)
    请问财务管理的作用有哪些?
    模仿 mapstruct 实现一个微服务编排框架(上)
    向 lambda 传递 this的拷贝
    RecyclerView的高效使用
    普洱茶上市?澜沧古茶通过港股聆讯
    C语言——函数
  • 原文地址:https://blog.csdn.net/m0_46085118/article/details/127868482