SQL的CASE表达式用法
case 表达式从SQL-92标准开始引入,因此是不依赖于具体的数据库技术,可提高SQL代码的可移植性。
case表达式注意事项:
1. 统一各个分支返回数据类型,并保证各个when字句的排他性,因为在发现为真的when字句时, case表达式真假值判断会终止,不会执行后边的判断;
2. 不要忘记写END;
3. 养成写ELSE字句的习惯,尽管不写ELSE语法并不会报错,但是如果前面条件不满足会返回NULL,有助于调试查找问题
case表达式常见用例:
1、用CHECK约束定义多个列的条件关系
比如规定公司男员工工资不得高于2000, 就可以写成
constriant check_salary check(case when sex = '' then
case when salary <= 2000 then 1
else 0 end
else 1 end =1)
不能写成逻辑与的关系 constraint check_salary check(sex = '2' and salary<= 2000),这样的话女性也不满足这个条件,无法被写入。
2、UPDATE字句进行调节分支
比如有需求将工资小于10000的调薪10%, 大于20000的降薪5%
| name | salary |
|---|---|
| June | 25000 |
| lucy | 9000 |
| sherry | 9800 |
| alina | 15000 |
如果你想用两个update,那就出错了,因为你会把salary给更新掉,一般情况会增加一个字段为调薪后字段,salary字段保持不变,但如果直接更新salary,就可以用case表达式
update Salaries set salary = case when salary <= 10000 then salary *1.1
when salary > 20000 then salary*0.95
else salary end;
注意最后的else字句千万不能丢,否则没有被捕获到的员工的工资会变为NULL
3、表之间数据匹配
有两张表,一张是课程表course,一张为每月开设的课程open_course
|
course_id |
course_name |
|---|---|
| 1 | 计算机网络 |
| 2 | 数据结构与算法 |
| 3 | 高性能MySQL |
| 4 | python核心编程 |
|
month_tab |
course_id |
|---|---|
| 201806 | 1 |
| 201806 | 3 |
| 201806 | 4 |
| 201807 | 4 |
| 201808 | 2 |
| 201808 | 4 |
Q3.1:将两张表转为交叉表,便于查看每月开设的课程
SQL1:
select course_name,
case when course_id in (
select course_id from sherry.openCourse where month_tab = '') then '〇'
else 'X' end as "6月",
case when course_id in (
select course_id from sherry.openCourse where month_tab = '') then '〇'
else 'X' end as "7月",
case when course_id in (
select course_id from sherry.openCourse where month_tab = '') then '〇'
else 'X' end as "8月"
from sherry.courseMaster

SQL2:
select month_tab,
case when max(case when course_id = 1 then 1 else 0 end) = 1 then '〇' else 'X' end as "计算机网络",
case when max(case when course_id = 2 then 1 else 0 end) = 1 then '〇' else 'X' end as "数据结构与算法",
case when max(case when course_id = 3 then 1 else 0 end) = 1 then '〇' else 'X' end as "高性能MySQL",
case when max(case when course_id = 4 then 1 else 0 end) = 1 then '〇' else 'X' end as "python核心编程"
from sherry.openCourse
group by month_tab
order by month_tab

4、将已有编号方式转换为新的方式并统计(聚合函数嵌套进case表达式)
Q4.1:比如查询某个城市男女分别有多少人,源表如下

select pre_name, sum(case when sex = 1 then population else 0 end) as "男", sum(case when sex = 2 then population else 0 end) as "女"
from sherry.popTbl2
group by pre_name

Q4.2:如果查询结果求每个地区共多少人
select case when pre_name in ('上海') then '华东地区'
when pre_name in ('北京') then '华北地区'
when pre_name in ('广州','深圳') then '华南地区'
end as area,
sum(population)
from sherry.popTbl2
group by case when pre_name in ('上海') then '华东地区'
when pre_name in ('北京') then '华北地区'
when pre_name in ('广州','深圳') then '华南地区'
end

注意group by 也要再写一遍,PostgreSQL可以直接写group by area,好像是因为在进行group by 操作前会先扫描一下select后面的字段。
5、聚合函数使用case表达式
仍然是源表sherry.popTbl2,如果把行结构数据转为列结构,即列为全国和各个地区,行为不同性别
select sex,sum(population) as "总和",sum(case when pre_name = '上海' then population else 0 end) as "上海",
sum(case when pre_name = '北京' then population else 0 end) as "北京",
sum(case when pre_name = '广州' then population else 0 end) as "广州",
sum(case when pre_name = '深圳' then population else 0 end) as "深圳"
from sherry.popTbl2
group by sex

6、order by字句使用case表达式
比如上述课程表course, 我们使用order by course_id, 则结果是1,2,3,4
Q6.1:但如果我们想结果为3,2,1,4呢,就可以用case表达式实现
select course_id from sherry.courseMaster
order by case when course_id = 3 then 1
when course_id = 2 then 2
when course_id = 1 then 3
when course_id = 4 then 4
end
参考:SQL进阶教程
SQL的CASE表达式用法的更多相关文章
- SQL Server case表达式的用法
★CASE表达式是一个标量表达式,它基于条件逻辑来返回一个值.因为CASE是一个标量表达式,所以它可以应用在SELECT.WHERE.HAVING以及ORDER BY子句中. CASE表达式有两种格式 ...
- 神奇的 SQL 之 CASE表达式,妙用多多 !
前言 历史考试选择题:黄花岗起义第一枪谁开的? A宋教仁 B孙中山 C黄兴 D徐锡麟,考生选C. 又看第二题:黄花岗起义第二枪谁开的? 考生傻了,就选了个B. 接着看第三题:黄花岗起义中,第三枪谁开的 ...
- 关于sql的case when用法简述
刚入手公司项目,需要添加一个功能,用到了SQL的case when以及concat SELECT eve.cc, eve.sc, case concat(cc,sc) ' THEN '' ' THEN ...
- SQL中CASE 的用法 转载
sql语言中有没有类似C语言中的switch case的语句?? 没有,用case when 来代替就行了. 例如,下面的语句显示中文年月 select getdat ...
- SQL之CASE WHEN用法详解[1]
简单CASE WHEN函数: CASE SCORE WHEN 'A' THEN '优' ELSE '不及格' END CASE SCORE WHEN 'B' THEN '良' ELSE '不及格' E ...
- SQL之CASE WHEN用法详解(转)
当我们需要从数据源上 直接判断数据显示代表的含义的时候 ,就可以在SQL语句中使用 Case When这个函数了. Case具有两种格式.简单Case函数和Case搜索函数. 第一种 格式 : 简单C ...
- sql语句-CASE WHEN用法详解
当我们需要从数据源上 直接判断数据显示代表的含义的时候 ,就可以在SQL语句中使用 Case When这个函数了. Case具有两种格式.简单Case函数和Case搜索函数. 第一种 格式 : 简单C ...
- sql的case when用法
select t.C_OPERATE_TIME MODIFY_TIME, t.c_code EMPLOYEE_CODE, t.c_name EMPLOYEE_NAME, CASE t.c_employ ...
- SQL之CASE WHEN用法详解
原文链接:https://blog.csdn.net/rongtaoup/article/details/82183743 原文链接:https://www.cnblogs.com/zhuyeshen ...
随机推荐
- jQuery动态加载JS以减少服务器压力
如果您要创建一个web2.0的应用程序,那么你的网页会包括大量的JavaScript文件,这些可能会拖慢您的网页.因此,动态加载JavaScript代码到您的网页是一个好主意,即只有当实用他们的时候加 ...
- mxnet编译问题手记
MXNet在64位Win7下的编译安装:https://www.cnblogs.com/noahzn/p/5506086.html http://blog.csdn.net/Jarvis_wxy/ar ...
- hihoCoder#1037 : 数字三角形(DP)
[题目链接]:click here~~ 时间限制:10000ms 单点时限:1000ms 内存限制:256MB 问题描写叙述 小Hi和小Ho在经历了螃蟹先生的任务之后被奖励了一次出国旅游的机会,于是他 ...
- 记CBS一次动人心魄的数据保卫战
接触分布式存储已经有一年多的时间了,首次遇到存储侧三份数据都有异常的情况,三份数据异常意味着客户数据的丢失,这个对云存储来讲是致命的打击.为了保证数据的安全,CBS运维和开发的同学进行了持续两天一夜的 ...
- MFC添加菜单资源与菜单执行函数的两种命令形式
添加资源->新建一个菜单资源->选择相应的对话框 菜单的执行函数命令形式: COMMAD 是指点击菜单后的执行命令 UPDATE_COMMAND_UI 是指点击菜单后菜单状态的函数
- poj 3714 Raid【(暴力+剪枝) || (分治法+剪枝)】
题目: http://poj.org/problem?id=3714 http://acm.hust.edu.cn/vjudge/contest/view.action?cid=27048#prob ...
- 九度OJ 1187:最小年龄的3个职工 (排序)
时间限制:1 秒 内存限制:32 兆 特殊判题:否 提交:2291 解决:936 题目描述: 职工有职工号,姓名,年龄.输入n个职工的信息,找出3个年龄最小的职工打印出来. 输入: 输入第一行包括1个 ...
- What is the difference between iterations and epochs in Convolution neural networks?
https://stats.stackexchange.com/questions/164876/tradeoff-batch-size-vs-number-of-iterations-to-trai ...
- Java 重写 equals 与 hashCode 的注意事项
为什么重写 equals 的时候必须重写 hashCode 大家可能从很多教程中了解到: SUN官方的文档中规定"如果重定义equals方法,就必须重定义hashCode方法,以便用户可以将 ...
- 2014阿里实习生面试题——MySQL如何实现索引的
这是2014阿里实习生北京站二面的一道试题: 在MySQL中,索引属于存储引擎级别的概念,不同存储引擎对索引的实现方式是不同的,比如MyISAM和InnoDB存储引擎. MyISAM索引实现: MyI ...