• [TimLinux] MySQL 中的CASE/WHEN语法


    1. 介绍章节

    MySQL 5.7-en.a4.pdf文档的第12章:Functions and Operators中的12.4Control Flow Functions介绍了流控制操作符:CASE、if()、IFNULL()、NULLIF()。

    2. 语法

    CASE value

      WHEN [compare_value] THEN result

      [WHEN [compare_value] THEN result ...]

      [ELSE result]

    END [AS COL_NAME]

    CASE 

      WHEN [condition] THEN result

      [WHEN [condition] THEN result ...]

      [ELSE result]

    END [AS COL_NAME]

    其中[AS COL_NAME]是我自己加上去的,取出的结果是一行中的COL_NAME字段的值。

    第一种语法,只是简单的判断value对应相等的compre_value的值,与编程语言中的switch (value) case value1:... case value2: 有些相似,只是进行value=compare_value的判断,找到了就返回THEN后的result值,都没有找到则取else后的result值,如果else语句不存在,则返回NULL值。

    第二种语法,则进行的是condition语句的判断操作,能够支持的比较操作符丰富多样,执行的方式与第一种语法一样。

    注意:两种语法,在第一个when已经匹配到值的情况下,都会返回不在继续对后续操作进行判断。

  • 相关阅读:
    1226 倒水问题
    1230 元素查找
    2152 滑雪
    1099 字串变换 2002年NOIP全国联赛提高组
    3027 线段覆盖 2
    P2066 机器分配
    spring的作用及优势---第一个spring示例
    密码框显示提示文字
    紫薇~还记得大明湖畔的HTML5智力拼图吗?
    细说javascript函数
  • 原文地址:https://www.cnblogs.com/timlinux/p/9105114.html
Copyright © 2020-2023  润新知