一、case when的使用方法
Case具有两种格式。简单Case函数和Case搜索函数。
第一种 格式 : 简单Case函数 :
格式说明
case 列名
when 条件值1 then 选项1
when 条件值2 then 选项2.......
else 默认值 end
eg:
select
case job_level
when '1' then '1111'
when '2' then '1111'
when '3' then '1111'
else 'eee' end
from dbo.employee
第二种 格式 :Case搜索函数
格式说明
case
when 列名= 条件值1 then 选项1
when 列名=条件值2 then 选项2.......
else 默认值 end
eg:
update employee
set e_wage =
case
when job_level = '1' then e_wage*1.97
when job_level = '2' then e_wage*1.07
when job_level = '3' then e_wage*1.06
else e_wage*1.05
end
提示:通常我们在写Case When的语句的时候,会容易忘记 end 这个结束,一定要记得哟!
比较: 两种格式,可以实现相同的功能。
简单Case函数的写法相对比较简洁,但是和Case搜索函数相比,功能方面会有些限制,比如写判断式。还有一个需要注意的问题,Case函数只返回第一个符合条件的 值,剩下的Case部分将会被自动忽略。
二、case when使用案例
下面我们来看一下,使用
Case
函数都能做些什么事情。
1、已知数据按照另外一种方式进行分组,分析
- 有如下数据:(为了看得更清楚,直接使用国家代码作为Primary Key)
data:image/s3,"s3://crabby-images/f7ef4/f7ef4ab2ee2a538550591f987886619424a19f51" alt=""
根据这个国家人口数据,统计各个大洲的人口数量
data:image/s3,"s3://crabby-images/1b0f3/1b0f31bbc90d66e889e689bea796ea3e69e73f86" alt=""
- 用这个方法来判断工资的等级,并统计每一等级的人数
data:image/s3,"s3://crabby-images/ee5cf/ee5cf3b69fa49ea65d1d06ec6f08f82c3ec3770d" alt=""
data:image/s3,"s3://crabby-images/2df15/2df150b28c4bfa2bea3f766f7c00cf74415cf379" alt=""
然后计算每一个等级的数量
data:image/s3,"s3://crabby-images/18f0c/18f0c49a3414c373f5e20c1ee8a6e02ebcc888fd" alt=""
方法2:
data:image/s3,"s3://crabby-images/334c1/334c16d6d8f7ecb2d7100d9ab915155067ddc09b" alt=""
2、竖表转横表
data:image/s3,"s3://crabby-images/54d2e/54d2ed03376fedf848a2da144889b723eb279324" alt=""
data:image/s3,"s3://crabby-images/3f107/3f10737360de0ef64d33e6e59d4d0ac848b4d047" alt=""
data:image/s3,"s3://crabby-images/a8ccc/a8ccc250eb26627223fcb0400fd09ca45bf08023" alt=""
3、根据条件有选择的update
data:image/s3,"s3://crabby-images/3115f/3115f4d15e48fbd2af989598e581545c679b8f89" alt=""
data:image/s3,"s3://crabby-images/67fc0/67fc0d4923a7cb2bd911aff34f8ff38ede0b5b66" alt=""
data:image/s3,"s3://crabby-images/34c6d/34c6db21ce44369cb991ae603056d431885655a8" alt=""