这篇文章在借鉴前人的基础上,进行了验证,感谢前人的分享
一、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/566df/566dfc74f0204fb260edb5b1a685f7e44d8ad4e8" alt="技术分享图片"
根据这个国家人口数据,统计各个大洲的人口数量
data:image/s3,"s3://crabby-images/f84d4/f84d40f15338d807c8d305939dee77caa9dcf4bd" alt="技术分享图片"
- 用这个方法来判断工资的等级,并统计每一等级的人数
data:image/s3,"s3://crabby-images/1b469/1b46962303775f461ef50d45b06251452ec2a8de" alt="技术分享图片"
data:image/s3,"s3://crabby-images/7aa60/7aa607fa53140d1db3e8a9e5de2a7e76f2f2dffa" alt="技术分享图片"
然后计算每一个等级的数量
data:image/s3,"s3://crabby-images/81dce/81dcefedc7f6c7970a75af845562f8f91fb91ed3" alt="技术分享图片"
方法2:
data:image/s3,"s3://crabby-images/cc2e3/cc2e3bf302dd3bf0163e78de98f754df09c2cb3e" alt="技术分享图片"
2、竖表转横表
data:image/s3,"s3://crabby-images/97f63/97f635b966547fe2bb25fa16c5bd6f3e7734c8a1" alt="技术分享图片"
data:image/s3,"s3://crabby-images/f01d1/f01d1e0f460e72c023f894b5bcaac69c152fd1df" alt="技术分享图片"
data:image/s3,"s3://crabby-images/0295d/0295dc0108f444b9c7218663423bb34cdbcf13ac" alt="技术分享图片"
3、根据条件有选择的update
data:image/s3,"s3://crabby-images/1e2f9/1e2f9095160228366b548e6aca928c06b8782ee9" alt="技术分享图片"
data:image/s3,"s3://crabby-images/fdfd7/fdfd7dfafc7cc3870a139ba50afab63a474215bc" alt="技术分享图片"
data:image/s3,"s3://crabby-images/b6a68/b6a6899380e9f4d67eb36688225992f1d62af0cc" alt="技术分享图片"