SQL中的case when then else end用法.docxVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
SQL中的case when then else end用法

SQL中的case when then else end用法Case具有两种格式。简单Case函数和Case搜索函数。--简单Case函数CASE sexWHEN1THEN男WHEN2THEN女ELSE其他END--Case搜索函数CASEWHEN sex = 1THEN男WHEN sex = 2THEN女ELSE其他END这两种方式,可以实现相同的功能。简单Case函数的写法相对比较简洁,但是和Case搜索函数相比,功能方面会有些限制,比如写判断式。还有一个需要注意的问题,Case函数只返回第一个符合条件的值,剩下的Case部分将会被自动忽略。--比如说,下面这段SQL,你永远无法得到“第二类”这个结果CASEWHEN col_1 IN ( a, b) THEN第一类WHEN col_1 IN (a) THEN第二类ELSE其他END下面我们来看一下,使用Case函数都能做些什么事情。一,已知数据按照另外一种方式进行分组,分析。有如下数据:(为了看得更清楚,我并没有使用国家代码,而是直接用国家名作为Primary Key) 国家(country)人口(population)中国600美国100加拿大100英国200法国300日本250德国200墨西哥50印度250根据这个国家人口数据,统计亚洲和北美洲的人口数量。应该得到下面这个结果。洲人口亚洲1100北美洲250其他700想要解决这个问题,你会怎么做?生成一个带有洲Code的View,是一个解决方法,但是这样很难动态的改变统计的方式。如果使用Case函数,SQL代码如下: SELECT SUM(population),CASE countryWHEN中国THEN亚洲WHEN印度THEN亚洲WHEN日本THEN亚洲WHEN美国THEN北美洲WHEN加拿大THEN北美洲WHEN墨西哥THEN北美洲ELSE其他ENDFROM Table_AGROUPBYCASE countryWHEN中国THEN亚洲WHEN印度THEN亚洲WHEN日本THEN亚洲WHEN美国THEN北美洲WHEN加拿大THEN北美洲WHEN墨西哥THEN北美洲ELSE其他END;同样的,我们也可以用这个方法来判断工资的等级,并统计每一等级的人数。SQL代码如下;SELECTCASEWHEN salary = 500 THEN1WHEN salary 500 AND salary = 600 THEN2WHEN salary 600 AND salary = 800 THEN3WHEN salary 800 AND salary = 1000 THEN4ELSENULLEND salary_class, COUNT(*)FROM Table_AGROUPBYCASEWHEN salary = 500 THEN1WHEN salary 500 AND salary = 600 THEN2WHEN salary 600 AND salary = 800 THEN3WHEN salary 800 AND salary = 1000 THEN4ELSENULLEND;二,用一个SQL语句完成不同条件的分组。有如下数据国家(country)性别(sex)人口(population)中国1340中国2260美国145美国255加拿大151加拿大249英国140英国260按照国家和性别进行分组,得出结果如下国家男女中国340260美国4555加拿大5149英国4060普通情况下,用UNION也可以实现用一条语句进行查询。但是那样增加消耗(两个Select部分),而且SQL语句会比较长。下面是一个是用Case函数来完成这个功能的例子SELECT country, SUM( CASEWHEN sex = 1THEN population ELSE 0 END), --男性人口 SUM( CASEWHEN sex = 2THEN population ELSE 0 END) --女性人口FROM Table_AGROUPBY country;这样我们使用Select,完成对二维表的输出形式,充分显示了Case函数的强大。三,在Check中使用Case函数。在Check中使用Case函数在很多情况下都是非常不错的解决方法。可能有很多人根本就不用Check,那么我建议你在看过下面的例子之后也尝试一下在SQL中使用Check。下面我们来举个例子公司A,这个公司有个规定,女职员的工资必须高于1000块。如果用Check和Case来表现的话,如下所示CONSTRAINT

文档评论(0)

yan698698 + 关注
实名认证
文档贡献者

该用户很懒,什么也没介绍

1亿VIP精品文档

相关文档