Sql ----- sqlserver 中的if 判断 case... when

与查询放到一块使用:

语法:

select 
case 
    when 范围条件 then 产生的结果
    when 范围条件  then 产生的结果
    else 不是以上范围产生的结果
end
from 表名

个人理解:

在英文中  case 表示事件,  when  表示  什么时候,then 表示那时,当时,

      else 表示否则,,end 表示 结束

那么就可以理解为   一件事的发生,有很多的事件段,在不同的时间段有不同的结果,可以用多个时间段和else 表示完整的事件,最后声明结束。

来个例子:一张表

 

 使用case  when  算所得税,工资小于等于三千不扣钱,在三千和四千之间(包含四千)扣200,在四千和五千之间(包含五千)扣400,五千以上扣800

 

也可以使用工资减去税收,计算实发

 

当这个事件是一个完整的事件的时候也可以,根据条件算总数平均数之类

计算 :表中学历是本科的总工资和职称是实习生的平均工资

这个时候else 也就不起作用了,可不写

 

 

 代码:

select Name,Gongzi,
(Gongzi-(case 
    when GongZi < =3000 then 0
    when (Gongzi >3000 and GongZi<= 4000) then 200 
    when (Gongzi >4000 and GongZi<= 5000) then 400 
    else 800
end)) as ShifaGongz

from dbo.obgexinzi


select 
sum (case 
    when  XueLi = '本科' then GongZi
    else 0
end) as benkezonggongzi,

avg (case 
    when ZhiCheng  ='实习生' then GongZi
end) as shixishenggongzi

from dbo.obgexinzi

 计算工资简单使用

 

 

select UserName,
   Exp_Decimal_01,Exp_Decimal_02,Exp_Decimal_04,Exp_Decimal_05,UserBankMark,
      (Exp_Decimal_01+Exp_Decimal_02) as Exp_Decimal_03,
      (Exp_Decimal_04+Exp_Decimal_05)  as  Exp_Decimal_06,
         
(case when (UserBankMark is null or UserBankMark='')  then 0
else (Exp_Decimal_01+Exp_Decimal_02)-(Exp_Decimal_04+Exp_Decimal_05)
end) as Exp_Decimal_07,

(case when not(UserBankMark is null or UserBankMark='')  then 0
else (Exp_Decimal_01+Exp_Decimal_02)-(Exp_Decimal_04+Exp_Decimal_05)
end) as Exp_Decimal_08


from tbmdGongZiList 

 

posted on 2019-12-09 14:49  obge  阅读(30686)  评论(0编辑  收藏  举报