-
2021-04-30 09:24:50
本帖最后由 Cynthia5 于 2014-10-8 20:35 编辑
case when 中是否可以在嵌套一个case when ?
例如:
取对应的美食类型代码(美食类型类型代码='001' 为蔬菜,美食类型类型代码='002' 则为海鲜,美食类型类型代码='003' 则为肉类)
如果为001的蔬菜,还需进一步查询。到蔬菜表中查询。取对应的蔬菜类型代码(蔬菜类型代码='01' 则为萝卜,蔬菜代码='02' 则为黄瓜,蔬菜类型代码='03' 则为白菜, 蔬菜类型代码='04' 则为土豆)
可以写成:
CASE
WHEN T3.OIP0_ORG='002' THEN '海鲜'
WHEN T3.OIP0_ORG='003' THEN '肉类'、
WHEN T3.OIP0_ORG='001' THEN
(CASE
WHEN T4.GRP0_GRP ='01' THEN '萝卜'
WHEN T4.GRP0_GRP ='02' THEN '黄瓜'
WHEN T4.GRP0_GRP ='03' THEN '白菜'
WHEN T4.GRP0_GRP ='04' THEN '土豆'END)
END,
这样吗?
更多相关内容 -
MySQL排序中使用CASE WHEN的方法示例
2020-12-16 11:07:36在之前的一个项目中,使用到了SQL中使用 CASE WHEN 排序的功能。现在写篇博客备忘~ 数据库版本:MySQL 5.6.42 条件: 某字段代表该数据的状态取值为非负整数,0表示无状态。 需求: 以该字段升序排序,同时需要将值... -
mysql case when group by 实例详解
2020-12-16 04:44:52mysql 中类似php switch case 的语句。 select xx字段, case 字段 when 条件1 then 值1 when 条件2 then 值2 else 其他值 END 别名 ...使用case when : select sum(redpackmoney) as stota, (CASE i -
MySQL中使用case when 语句实现多条件查询的方法
2020-12-15 08:15:19举例如下: 数据表为DemoTable,字段有id,... 可使用case when来实现这个条件,需要嵌套子查询语句 sql语句代码示例如下: 代码如下: SELECT * FROM DemoTable WHERE ((SELECT CASE 1 WHEN condition1满足条件 THEN 1 E -
oracle where case when where后面跟case when
2019-04-21 01:01:02NULL 博文链接:https://vernonchen163.iteye.com/blog/1908053 -
SqlServer使用 case when 解决多条件模糊查询问题
2020-09-10 05:01:27主要介绍了SqlServer使用 case when 解决多条件模糊查询问题 的相关资料,需要的朋友可以参考下 -
case when then语句用法
2018-04-18 09:40:46该语句的执行过程是:将CASE后面表达式的值与各WHEN子句中的表达式的值进行比较,如果两者相等,则返回THEN后的表达式的值,然后跳出CASE语句,否则返回ELSE子句中的表达式的值。ELSE子句是可选项。当CASE语句中不... -
case when和sum case when 写法及拼接字段
2016-06-03 21:51:201 case when 写法 2 sum case when 用法 3 select 拼接字段 示例如下: when 2 then 'C' else 'D' end ) as '类型',count(*) as '数量' from table group by orderType -
Case When
2020-12-24 14:15:401、简单Case函数CASE sexWHEN '1' THEN '男'WHEN '2' THEN '女'ELSE '其他' END2、Case搜索函数CASE WHEN sex = '1' THEN '男'WHEN sex = '2' THEN '女'ELSE '其他' END例如:SELECT id, name, cj, (CASE WH...Case具有两种格式。简单Case函数和Case搜索函数。
1、简单Case函数
CASE sex
WHEN '1' THEN '男'
WHEN '2' THEN '女'
ELSE '其他' END
2、Case搜索函数
CASE WHEN sex = '1' THEN '男'
WHEN sex = '2' THEN '女'
ELSE '其他' END
例如:
SELECT id, name, cj, (CASE WHEN cj < 60 THEN '不及格' WHEN cj BETWEEN 60 AND 90 THEN '良好' WHEN cj > 90 THEN '优秀' END) AS 状态
FROM stud
这两种方式,可以实现相同的功能。简单Case函数的写法相对比较简洁,但是和Case搜索函数相比,功能方面会有些限制,比如写判断式。
还有一个需要注意的问题,Case函数只返回第一个符合条件的值,剩下的Case部分将会被自动忽略。
--比如说,下面这段SQL,你永远无法得到“第二类”这个结果
CASE WHEN 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 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 55
加拿大 1 51
加拿大 2 49
英国 1 40
英国 2 60
按照国家和性别进行分组,得出结果如下
国家 男 女
中国 340 260
美国 45 55
加拿大 51 49
英国 40 60
普通情况下,用UNION也可以实现用一条语句进行查询。但是那样增加消耗(两个Select部分),而且SQL语句会比较长。
下面是一个是用Case函数来完成这个功能的例子
SELECT country,
SUM( CASE WHEN sex = '1' THEN
population ELSE 0 END), --男性人口
SUM( CASE WHEN sex = '2' THEN
population ELSE 0 END) --女性人口
FROM Table_A
GROUP BY country;
这样我们使用Select,完成对二维表的输出形式,充分显示了Case函数的强大。
三,在Check中使用Case函数。
在Check中使用Case函数在很多情况下都是非常不错的解决方法。可能有很多人根本就不用Check,那么我建议你在看过下面的例子之后也尝试一下在SQL中使用Check。
下面我们来举个例子
公司A,这个公司有个规定,女职员的工资必须高于1000块。如果用Check和Case来表现的话,如下所示
CONSTRAINT check_salary CHECK
( CASE WHEN sex = '2'
THEN CASE WHEN salary > 1000
THEN 1 ELSE 0 END
ELSE 1 END = 1 )
如果单纯使用Check,如下所示
CONSTRAINT check_salary CHECK
( sex = '2' AND salary > 1000 )
女职员的条件倒是符合了,男职员就无法输入了。
例子:
从stud_grade表中查询所有同学考试成绩情况,凡成绩为空者输出“未考”、小于60分输出“不及格”、60分至70分输出“及格”、70分至90分输出“良好”、大于或等于90分时输出“优秀”。
SELECT stud_id,name,score=CASE WHEN grade IS NULL THEN ’未考’
WHEN grade<60 THEN ’不及格’
WHEN grade>=60 AND grade<70 THEN ’及格’
WHEN grade>=70 AND grade<90 THEN ’良好’
。。
-
oracle case when 语句的用法详解
2020-12-16 02:49:231. CASE WHEN 表达式有两种形式 代码如下:–简单Case函数 CASE sex WHEN ‘1’ THEN ‘男’ WHEN ‘2’ THEN ‘女’ ELSE ‘其他’ END –Case搜索函数 CASEWHEN sex = ‘1’ THEN ‘男’ WHEN sex = ‘2’ ... -
case when
2020-12-22 14:13:07这篇文章在借鉴前人的基础上,进行了验证,感谢前人的分享一、case when的使用方法Case具有两种格式。简单Case函数和Case搜索函数。第一种 格式 :简单Case函数 :格式说明case 列名when 条件值1 then 选项1when 条件...这篇文章在借鉴前人的基础上,进行了验证,感谢前人的分享
一、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、已知数据按照另外一种方式进行分组,分析
有如下数据:(为了看得更清楚,直接使用国家代码作为PrimaryKey)
根据这个国家人口数据,统计各个大洲的人口数量
用这个方法来判断工资的等级,并统计每一等级的人数
输出每一个人的薪资等级
然后计算每一个等级的数量
方法1:
方法2:
2、竖表转横表
如下表所示,统计日本、泰国不同性别的人口,“sex”中1代表男性、2代表女性、3代表无性、4代表双性,
要求以(国家、男性、女性、无性、双性)为字段输出表。
首先生成确定的字段(国家、男性、女性、无性、双性),
然后以case when来判断性别中人口的取值,并输出表如下图:
最后使用group by来通过国家分组,并取其中的最大值(有的人会使用sum求和,效果也是一样的)
最终结果如下图:
3、根据条件有选择的update
P_key是表A_TEST1的主键,结果a和b的顺序搞反了,这是需要把a和b倒换过来,一般情况下,要想把两条数据的Primary key,a和b交换,需要经过临时存储,拷贝,读回数据的三个过程,要是使用Case函数的话,一切都变得简单多了。
使用下列方式可将主键a、b替换过来
但这里有一个问题一定要注意,else 后面一定要将原有的值放进来,否则除了a、b意外的值会被置成null,如下图
-
sql 中 case when 语法使用方法
2020-09-11 06:23:50sql语言中有没有类似C语言中的switch case的语句? -
sql语句中case when及select case when的用法
2019-11-28 14:40:53Case具有两种格式:简单Case函数和Case搜索函数。 一:简单Case函数 case sex when '1' then '男' when '2' then '女' else '其他' end 二:Case搜索函数 case when sex = '1' then '男' when sex = '2' ...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
下面我们来看一下,使用Case函数都能做些什么事情。
一,已知数据按照另外一种方式进行分组
分析,有如下数据:(为了看得更清楚,我并没有使用国家代码,而是直接用国家名作为主键:Primary Key)
需求:根据这个国家人口数据,统计亚洲和北美洲的人口数量。
应该得到下面这个结果:
解决这个问题,你会怎么做?生成一个带有洲Code的View是一个解决方法,但是这样很难动态的改变统计的方式。如果使用Case函数,SQL代码如下:select case country when '中国' then '亚洲' when '印度' then '亚洲' when '日本' then '亚洲' when '美国' then '北美洲' when '加拿大' then '北美洲' when '墨西哥' then '北美洲' else '其他' end as 洲, -- 起别名 sum(population) as 人口 -- 起别名 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 as 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语句完成不同条件的分组
有如下数据:
按照国家和性别进行分组,得出结果如下:
普通情况下,用UNION(并集)也可以实现用一条语句进行查询。但是那样增加消耗(两个Select部分),而且SQL语句会比较长。下面是一个是用Case函数来完成这个功能的例子:select country, sum(case when sex='1' then population else 0 end) as 男, --男性人口 sum(case when sex='2' then population else 0 end) as 女 --女性人口 from table_a group by country;
这样我们使用Select,完成对二维表的输出形式,充分显示了Case函数的强大。
三,在Check中使用Case函数
在Check中使用Case函数在很多情况下都是非常不错的解决方法。可能有很多人根本就不用Check,那么我建议你在看过下面的例子之后也尝试一下在SQL中使用Check。
下面我们来举个例子:
公司A,这个公司有个规定,女职员的工资必须高于1000块。如果用Check和Case来表现的话,如下所示:then 1 else 0 end else 1 end = 1 ) 如果单纯使用check: constraint check_salary check ( sex = '2' and salary > 1000 ) 女职员的条件倒是符合了,男职员就无法输入了。
四,根据条件有选择的update
例,有如下更新条件
1.工资5000以上的职员,工资减少10%
2.工资在2000到4600之间的职员,工资增加15%
很容易考虑的是选择执行两次update语句,如下所示
– 条件1update personnel set salary = salary * 0.9 where salary >= 5000;
– 条件2
update personnel set salary = salary * 1.15 where salary >= 2000 and salary < 4600;
但是事情没有想象得那么简单,问题:假设有个人工资5000块。首先,按照条件1,工资减少10%,变成工资4500。接下来运行第二个SQL时候,因为这个人的工资是4500在2000到4600的范围之内,需增加15%,最后这个人的工资结果是5175,不但没有减少,反而增加了。如果要是反过来执行,那么工资4600的人相反会变成减少工资。暂且不管这个规章是多么荒诞,如果想要一个sql语句实现这个功能的话,我们就需要用到Case函数。代码如下:
// 说明:库表:personnel中的每一行数据都会被更新 update personnel set salary = (case when salary >= 5000 then salary * 0.9 when salary >= 2000 and salary < 4600 then salary * 1.15 else salary end)
这里要注意一点,最后一行的else salary是必需的,要是没有这行,不符合这两个条件的人的工资将会被写成null,那可就大事不妙了。
注意:在Case函数中Else部分的默认值是null,这点是需要注意的地方。
这种方法还可以在很多地方使用,比如说变更主键这种累活。
一般情况下,要想把两条数据的Primary key,a和b交换,需要经过临时存储,拷贝,读回数据的三个过程,要是使用Case函数的话,一切都变得简单多了。p_key col_1 col_2 a 1 张三 b 2 李四 c 3 王五 假设有如上数据,需要把主键a和b相互交换。
用Case函数来实现的话,代码如下:update sometable set p_key = (case when p_key = 'a' then 'b' when p_key = 'b' then 'a' else p_key end) where p_key in ('a', 'b');
同样的也可以用来交换两个unique key。
需要注意的是,如果有需要交换主键的情况发生,多半是当初对这个表的设计进行得不够到位,建议检查表的设计是否妥当。五,两个表数据是否一致的检查
Case函数不同于DECODE函数。在Case函数中,可以使用:between, like, is null, in, exists等等。比如说使用in, exists,可以进行子查询,从而实现更多的功能。
下面具个例子来说明,有两个表:tbl_A,tbl_B,两个表中都有keyCol列。现在我们对两个表进行比较,tbl_A中的keyCol列的数据如果在tbl_B的keyCol列的数据中可以找到,返回结果’Matched’,如果没有找到,返回结果’Unmatched’。
要实现下面这个功能,可以使用下面两条语句
– 使用in的时候:select keycol, case when keycol in (select keycol from tbl_b) then 'matched' else 'unmatched' end as label from tbl_a;
– 使用exists的时候:
select keycol, case when exists (select * from tbl_b where tbl_a.keycol = tbl_b.keycol) then 'matched' else 'unmatched' end as label from tbl_a;
使用in和exists的结果是相同的。也可以使用not in和not exists,但是这个时候要注意null的情况。
六,在Case函数中使用合计函数
假设有下面一个表:
学号(std_id) 课程ID(class_id) 课程名(class_name) 主修flag(main_class_flg) 100 1 经济学 Y 100 2 历史学 N 200 2 历史学 N 200 3 考古学 Y 200 4 计算机 N 300 4 计算机 N 400 5 化学 N 500 6 数学 N 有的学生选择了同时修几门课程(100,200)也有的学生只选择了一门课程(300,400,500)。选修多门课程的学生,要选择一门课程作为主修,主修flag里面写入Y。只选择一门课程的学生,主修flag为N(实际上要是写入Y的话,就没有下面的麻烦事了,为了举例子,还请多多包含)。
现在我们要按照下面两个条件对这个表进行查询:
1,只选修一门课程的人,返回那门课程的ID
2,选修多门课程的人,返回所选的主课程ID
简单的想法就是,执行两条不同的SQL语句进行查询。
–条件1:只选择了一门课程的学生select std_id, max(class_id) as main_class from studentclass group by std_id having count(*) = 1;
执行结果1:
std_id main_class 300 4 400 5 500 6 –条件2:选择多门课程的学生
select std_id, class_id as main_class from studentclass where main_class_flg = 'Y';
执行结果2:
std_id main_class 100 1 200 3 如果使用Case函数,我们只要一条SQL语句就可以解决问题,具体如下所示:
select std_id, case when count(*) = 1 then max(class_id) else max(case when main_class_flg = 'y' then class_id else null end) end as main_class from studentclass group by std_id;
运行结果:
std_id main_class 100 1 200 3 300 4 400 5 500 6 通过在Case函数中嵌套Case函数,在合计函数中使用Case函数等方法,我们可以轻松的解决这个问题。使用Case函数给我们带来了更大的自由度。
最后提醒一下使用Case函数的新手注意不要犯下面的错误:// 错误的写法 case col_1 when 1 then 'right' when null then 'wrong' end
在这个语句中when null这一行总是返回unknown,所以永远不会出现wrong的情况。因为这句实际表达的意思是:when col_1 = null,这是一个错误的用法,这个时候我们应该选择用:when col_1 is null。
七、小结
select与case结合使用最大的好处有两点:一是在显示查询结果时可以灵活的组织格式,二是有效避免了多次对同一个表或几个表的访问。
下面举个简单的例子来说明。
例如表:students(id, name ,birthday, sex, grade), – sex:男女标志(1:男,2:女),-- grade年级。要求按每个年级统计男生和女生的数量各是多少,统计结果的表头为:年级,男生数量,女生数量。如果不用select case when,为了将男女数量并列显示,统计起来非常麻烦,先确定年级信息,再根据年级取男生数和女生数,而且很容易出错。
用select case when写法如下:
结论:
1,count(1)与count(*)得到的结果一致,包含null值。
2,count(字段)不计算null值
3,count(null)结果恒为0// 原理:count(arg) // 对于一行来说,若括号内的参数arg的值若不是null,则count++, // 否则对该行不予计数。 select grade, count(case when sex = 1 then 1 // 这里可以是不为null的任意数字 else null end) as 男生数量, count(case when sex = 2 then 1 // 这里可以是不为null的任意数字 else null end) as 女生数量 from students group by grade;
OR
select grade, sum(case when sex = 1 then 1 // 这里只能是1 else 0 end) as 男生数量, sum(case when sex = 2 then 1 // 这里只能是1 else 0 end) as 女生数量 from students group by grade;
count函数:count(arg)的底层原理:
count(*)流程(于sub_select函数中)
上层的流程与代码是比较简单的,集中在 sub_select 函数中,其中 2 类函数分别对应于前面”执行框架”部分所述的 2 个步骤 – 读取、计数。先给出结论如下:
(1)读取一行:从相对顶层的 sub_select 函数经过一番调用,最终所有分支将调用到 row_search_mvcc 函数中,该函数就是用于从 InnoDB 存储引擎所存储的 B±tree 结构中读取一行到内存中的一个 buf (uchar * ) 中,待后续处理使用。
(2)计数一行: 代码层面,将会在 evaluate_join_record 函数中对所读取的行进行评估,看其是否应当计入 count 中 (即是否要count++)。
简单来说,count(arg)本身为 MySQL 的函数操作,对于一行来说,若括号内的参数arg的值若不是null,则count++,否则对该行不予计数。 -
CASE WHEN 及 SELECT CASE WHEN的用法
2018-08-26 19:14:59Case具有两种格式。简单Case函数和Case搜索函数。 简单Case函数 CASE sex WHEN '1' THEN '男' ...CASE WHEN sex = '1' THEN '男' WHEN sex = '2' THEN '女' ELSE '其他' END 种方式,... -
sql语句中case when then 用法
2021-12-22 15:39:13sql语句中case when then 用法 -
mysql中case when的用法
2022-05-01 17:31:24case when的使用情况有三种 等值转换 范围转换 列转行操作 1.等值转换 设计数据库的时候总会把用户的性别用int存储('0’为女,'1’为男),但是怎么把它抓换成汉字显示呢? select name as '姓名', (case ... -
MySQL case when 使用
2021-01-18 19:59:03--简单case函数case sexwhen '1' then '男'when '2' then '女’else '其他' end--case搜索函数case when sex = '1' then '男'when sex = '2' then '女'else '其他' end这两种方式,可以实现相同的功能。简单case函数... -
SQL之CASE WHEN用法详解
2021-02-09 01:30:01简单CASE WHEN函数:CASE SCORE WHEN 'A' THEN '优' ELSE '不及格' ENDCASE SCORE WHEN 'B' THEN '良' ELSE '不及格' ENDCASE SCORE WHEN 'C' THEN '中' ELSE '不及格' END等同于,使用CASE WHEN条件表达式函数实现... -
Spark CASE WHEN 写法案例
2022-01-20 17:52:26今天才写一个Spark的大数据报表的时候,遇到一个group by结合Case When的语法问题,现将问题的详细经过记录下来,希望可以对有遇到这个问题伙伴一些帮助。 二、问题 运行报错详细如下截图: 很明显是case ... -
MySQL case when then 的使用方法
2022-03-09 11:22:00阅读目录简单 CASE WHEN 函数场景1场景2场景3 简单 CASE WHEN 函数 CASE SCORE WHEN 'A' THEN '优' ELSE '不及格' END CASE SCORE WHEN 'B' THEN '良' ELSE '不及格' END CASE SCORE WHEN 'C' THEN '中' ELSE '不... -
ORACLE CASE WHEN 及 SELECT CASE WHEN的用法
2022-01-05 22:31:03Case具有两种格式。简单Case函数和Case搜索函数。 --简单Case函数 CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ...CASE WHEN sex = '1' THEN '男' WHEN sex = '2' THEN '女' ELSE '其他' END ... -
sql语言中group by和case when及sum(case when)的结合使用
2021-03-21 21:02:22group by和case when结合使用 如下示代码块,group by 按case when得到的列分组计算,且select时,select 中的case when 与group by中保持一致。 select case when substr(upper(depend_name),1,4)='JCW_' then ... -
sql 函数 CASE WHEN
2022-04-24 16:17:50case when 相当于 java 语言中的 if {} esle {} 判断、switch case 语句。该语句执行时,先对条件进行判断,然后根据判断结果进行响应的操作。 Case 有两种格式:简单Case函数 和 Case搜索函数 简单Case 函数: ... -
SQL Server Case when 的使用方法总结
2022-01-06 10:42:59SQL Server 中case when...then...语句的使用方法及场景 -
sql之case when用法详解
2021-03-09 17:33:32简单CASE WHEN函数只能应对一些简单的业务场景,而CASE WHEN条件表达式的写法则更加灵活。CASE WHEN条件表达式函数:类似JAVA中的IF ELSE语句。简单CASE WHEN函数:CASE SCORE WHEN 'A' THEN '优' ELSE '不及格' END... -
case when、连续区间查询
2022-02-27 16:49:34最近为了帮其他组赶项目,着实当了一把hive sql工具人,最大的收获还是系统的了解了case when、开窗函数的应用。为了便于以后回顾使用,特整理成文章进行记录分享。 一、case when 1.1 定义 hive官网(CASE ... -
Oracle中Case When的用法
2021-11-08 20:18:28一、Case的两种表达式 1.1、简单的case表达式 SELECT CASE 列名 WHEN 值1 THEN 結果1 WHEN 值2 THEN 結果2 ELSE 结果3 END FROM table1; 1.2、检索的cse表达式 SELECT CASE WHEN 条件1 THEN ... -
Mybatis CASE WHEN 的用法
2022-04-27 11:34:08Mybatis CASE WHEN 的用法 Case具有两种格式。简单Case函数和Case搜索函数。 简单Case函数 CASE sex WHEN ‘1’ THEN ‘男’ WHEN ‘2’ THEN ‘女’ ELSE ‘其他’ END –Case搜索函数 CASE WHEN sex = ‘1’ THEN ...