- 1、本文档共5页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 5、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 6、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 7、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 8、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
SQL中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
这两种方式,可以实现相同的功能。简单Case函数的写法相对比较简洁,但是和Case搜索函数相比,功能方面会有些限制,比如写判断式。还有一个需要注意的问题,Case函数只返回第一个符合条件的值,剩下的Case部分将会被自动忽略。
--比如说,下面这段SQL,将永远无法得到“第二类”这个结果
CASE WHEN col_1 IN (a, b) THEN 第一类
WHEN col_1 IN (a) THEN 第二类
ELSE其他 END
一,已知数据按照另外一种方式进行分组,分析。
有如下数据:(用国家名作为Primary Key)
国家(country)人口(population)
中国 600
美国 100
加拿大 100
英国 200
法国 300
日本 250
德国 200
墨西哥 50
印度 250
根据这个国家人口数据,统计亚洲和北美洲的人口数量。应该得到下面这个结果。
洲 人口
亚洲 1100
北美洲 250
其他 700
想要解决这个问题,生成一个带有洲的View,是一个解决方法,但是这样很难动态的改变统计的方式。如果使用Case函数,SQL代码如下:
SELECT SUM(population),
CASE country
WHEN 中国 THEN 亚洲
WHEN 印度 THEN 亚洲
WHEN 日本 THEN 亚洲
WHEN 美国 THEN 北美洲
WHEN 加拿大 THEN 北美洲
WHEN 墨西哥 THEN 北美洲
ELSE 其他 END
FROM Table_A
GROUP BY CASE country
WHEN 中国 THEN 亚洲
WHEN 印度 THEN 亚洲
WHEN 日本 THEN 亚洲
WHEN 美国 THEN 北美洲
WHEN 加拿大 THEN 北美洲
WHEN 墨西哥 THEN 北美洲
ELSE 其他 END;
同样也可以用这个方法来判断工资的等级,并统计每一等级的人数。SQL代码如下;
SELECT
CASE WHEN salary = 500 THEN 1
WHEN salary 500 AND salary = 600 THEN 2
WHEN salary 600 AND salary = 800 THEN 3
WHEN salary 800 AND salary = 1000 THEN 4
ELSE NULL END salary_class,
COUNT(*)
FROM Table_A
GROUP BY
CASE WHEN salary = 500 THEN 1
WHEN salary 500 AND salary = 600 THEN 2
WHEN salary 600 AND salary = 800 THEN 3
WHEN salary 800 AND salary = 1000 THEN 4
ELSE NULL END;
二,用一个SQL语句完成不同条件的分组。
有如下数据
国家(country)性别(sex)人口(population)
中国 1 340
中国 2 260
美国 1 45
美国 2
您可能关注的文档
- solidworks简介.doc
- SOPC复习资料.doc
- SourceInsight配置WinAVR.doc
- Spchange流程.doc
- SPOOL号码满分析.doc
- spring jar 包详解.doc
- Spring MVC框架的高级配置.doc
- Spring 编程入门十大问题解答.doc
- Spring的mvc模式.doc
- Spring对持久层封装.doc
- 2025年中山市沙溪镇人民政府所属事业单位招聘11人笔试备考题库及参考答案详解一套.docx
- 2025年中山市横栏镇人民政府所属事业单位第二期招聘笔试高频难、易错点备考题库及参考答案详解一套.docx
- 2025年中山市横栏镇人民政府所属事业单位第二期招聘笔试高频难、易错点备考题库含答案详解.docx
- 2025年中山市阜沙镇人民政府所属事业单位招聘笔试高频难、易错点备考题库及完整答案详解1套.docx
- 2025年中山市阜沙镇人民政府所属事业单位招聘笔试高频难、易错点备考题库参考答案详解.docx
- 2025年中山市阜沙镇人民政府所属事业单位招聘笔试备考题库附答案详解.docx
- 2025年中山市阜沙镇人民政府所属事业单位招聘笔试高频难、易错点备考题库附答案详解.docx
- 2025年中山市阜沙镇人民政府所属事业单位招聘笔试备考题库附答案详解.docx
- 2025年中山市阜沙镇人民政府所属事业单位招聘笔试备考题库及答案详解一套.docx
- 2025年中山市阜沙镇人民政府所属事业单位招聘笔试备考题库及完整答案详解1套.docx
文档评论(0)