1.case when then else end最常用是用来分组的,
以case开头,end结束。when和then相当于“如果...那么”,else相当于如果以上都不成立,那么就....
case函数只返回第一个符合条件的值,剩下的Case部分将会被自动忽略:
--比如说,下面这段SQL,你永远无法得到“第二类”这个结果 :
CASE WHEN col_1 IN ( 'a', 'b') THEN '第一类'
WHEN col_1 IN ('a') THEN '第二类'
ELSE'其他' END
Case具有两种格式。简单Case函数和Case搜索函数,这两种方式,可以实现相同的功能。简单Case函数的写法相对比较简洁,但是和Case搜索函数相比,功能方面会有些限制,比如写判断式:
--简单Case函数
CASE sex
WHEN '1' THEN '男'
WHEN '2' THEN '女'
ELSE '其他' END
--Case搜索函数
CASE WHEN sex = '1' THEN '男'
WHEN sex = '2' THEN '女'
ELSE '其他' END