case when条件表达式

SQL CASE 表达式是一种通用的条件表达式,类似于其它语言中的 if/else 语句。 

CASE WHEN condition THEN result 
[WHEN ...] 
[ELSE result] 
END 

CASE 子句可以用于任何表达式可以有效存在的地方。 condition 是一个返回boolean 的表达式。 如果结果为真,那么 CASE 表达式的结果就是符合条件的 result。 如果结果为假,那么以相同方式搜寻任何随后的 WHEN 子句。 如果没有 WHEN condition 为真,那么 case 表达式的结果就是在 ELSE 子句里的值。 如果省略了 ELSE 子句而且没有匹配的条件, 结果为 NULL。

  1. 例子:   
  2.   
  3. SELECT * FROM test;   
  4. a   
  5. ---   
  6. 1   
  7. 2   
  8. 3   
  9. SELECT a,   
  10. CASE WHEN a=1 THEN 'one'   
  11. WHEN a=2 THEN 'two'   
  12. ELSE 'other'   
  13. END   
  14. FROM test;   
  15. a | case   
  16. ---+-------   
  17. 1 | one   
  18. 2 | two   
  19. 3 | other 

所有 result 表达式的数据的类型都必须可以转换成单一的输出类型。  

下面这个"简单的" CASE 表达式是上面的通用形式的一个特殊的变种。

  1. CASE expression   
  2. WHEN value THEN result   
  3. [WHEN ...]   
  4. [ELSE result]   
  5. END   

先计算 expression 的值, 然后与所有在WHEN 子句里声明的 value 对比,直到找到一个相等的。 如果没有找到匹配的,则返回在 ELSE 子句里的 result (或者 NULL)。 这个类似于 C 里的 switch 语句。 

上面的例子可以用简单 CASE 语法来写:

  1. SELECT a,   
  2. CASE a WHEN 1 THEN 'one'   
  3. WHEN 2 THEN 'two'   
  4. ELSE 'other'   
  5. END   
  6. FROM test;   
  7. a | case   
  8. ---+-------   
  9. 1 | one   
  10. 2 | two   
  11. 3 | other 

CASE 表达式并不计算任何对于判断结果并不需要的子表达式。 比如,下面是一个可以避免被零除的方法: 

SELECT ... WHERE CASE WHEN x <> 0 THEN y/x > 1.5 ELSE false END; 
例1:一道SQL语句面试题 
表内容: 
2005-05-09 胜 
2005-05-09 胜 
2005-05-09 负 
2005-05-09 负 
2005-05-10 胜 
2005-05-10 负 
2005-05-10 负 

如果要生成下列结果, 该如何写sql语句? 

            胜 负 
2005-05-09  2  2 
2005-05-10  1  2 

  1. create table #tmp(rq varchar(10),shengfu nchar(1))   
  2.   
  3. insert into #tmp values('2005-05-09','胜')   
  4. insert into #tmp values('2005-05-09','胜')   
  5. insert into #tmp values('2005-05-09','负')   
  6. insert into #tmp values('2005-05-09','负')   
  7. insert into #tmp values('2005-05-10','胜')   
  8. insert into #tmp values('2005-05-10','负')   
  9. insert into #tmp values('2005-05-10','负')   
  10. select rq, sum(case when shengfu='胜' then 1 else 0 end)'胜',   
  11.            sum(case when shengfu='负' then 1 else 0 end)'负'   
  12.            from #tmp group by rq   
  13. ---------------------------------------------------------- 

例3:有一张表,里面有3个字段:语文,数学,英语。其中有3条记录分别表示语文70分,数学80分,英语58分,请用一条sql语句查询出这三条记录并按以下条件显示出来(并写出您的思路): 
   大于或等于80表示优秀,大于或等于60表示及格,小于60分表示不及格。  
       显示格式:  
       语文              数学                英语  
       及格              优秀                不及格    
----------------------------------------------------------

  1. select   
  2.     (case when 语文>=80 then '优秀'   
  3.           when 语文>=60 then '及格'   
  4.           else '不及格' end) as 语文,   
  5.     (case when 数学>=80 then '优秀'   
  6.           when 数学>=60 then '及格'   
  7.           else '不及格' end) as 数学,   
  8.     (case when 英语>=80 then '优秀'   
  9.           when 英语>=60 then '及格'   
  10.           else '不及格' end) as 英语,   
  11. from table  


  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值