DB2 的 case when then else end 条件分支的处理

两种语法模式:


(1):只有一个分支

 

     CASE
        WHEN 条件  THEN 结果1
        ELSE            结果2
      END
(2):支持多种分支

 

     CASE 表达式1
        WHEN 表达式2   THEN 结果1
        ELSE            结果2
   END
上面的WHEN可以重复多次,

 

===================

 

简单示例:

 

  1. select    
  2.     case when 1 = 1  
  3.     then 1  
  4.     else 2  
  5.     end;  
  1. select    
  2.     case 2  
  3.     when 1 then 1  
  4.     when 2 then 2  
  5.     when 3 then 3  
  6.     else 4  
  7.     end;  

============================

 

 

下面详细的各举几个例子,这些例子可以用于ESQL和交互式的SQL中
eg1:处理被0除

[java]  view plain copy
  1. SELECT   
  2. CASE   
  3. WHEN fileld1=0 THEN 0  
  4. ELSE fileld2/field1  
  5. END  
  6. FROM  FILE  


eg2:字段值对应转换
[java]  view plain copy
  1. SELECT ORDNO,CUSNAM,SHIPDATE,CASE  
  2.                 WHEN SHIPDATE<CURDATE()  THEN 'OVERDUE'  
  3.                 WHEN SHIPDATE=CURDATE()  THEN 'PROCESSING'  
  4.                 WHEN SHIPDATE>;CURDATE()  THEN 'ACTIVE'  
  5.               END  
  6. FROM FILE  


eg3:获取月份的名字:上面的例子
[java]  view plain copy
  1. SELECT ORDNO,CUSNO,  
  2.    CASE  MONTH(SHIPDATE)  
  3.    WHEN  '01'   THEN 'Jan'  
  4.    WHEN  '02'   THEN 'Feb'  
  5.    WHEN  '03'   THEN 'Mar'  
  6.    WHEN  '04'   THEN 'Apr'  
  7.    WHEN  '05'   THEN 'May'  
  8.    WHEN  '06'   THEN 'Jun'  
  9.    WHEN  '07'   THEN 'Jul'  
  10.    WHEN  '08'   THEN 'Aug'  
  11.    WHEN  '09'   THEN 'Sep'  
  12.    WHEN  '10'   THEN 'Oct'  
  13.    WHEN  '11'   THEN  'Nov'  
  14.    WHEN  '12'   THEN  'Dec'  
  15.    END  
  16. FROM FILE  
  

 

===================

 

CASE很好用,不仅SELECT可以用,UPATE里面也蛮灵

以上是关于查询的  下面再来个 update的

 

贴代码直观:

 

 

[c-sharp]  view plain copy
  1. UPDATE properities  
  2. SET   taxrate=  
  3.    CASE   
  4.        WHEN area<10000 THEN 0.05  
  5.        WHEN area<20000 THEN 0.07  
  6.        ELSE 0.09  
  7.    END  

  • 2
    点赞
  • 9
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
DB2中,可以使用CASE WHEN、ELSEIF和ELSE语句来创建条件表达式。这些语句通常与SELECT、UPDATE和DELETE等查询和更新语句一起使用。 CASE WHEN语句用于根据条件表达式的返回结果进行不同的操作。它根据CASE WHEN后面的条件表达式的结果,选择一个特定的执行路径,并返回相应的结果。语法如下: ```sql CASE <expression> WHEN <value1> THEN <result1> WHEN <value2> THEN <result2> ... ELSE <result> END ``` 其中,<expression>是用于评估的条件表达式,<value1>、<value2>等是可能的值,<result1>、<result2>等是对应于每个条件的返回结果。如果条件表达式的结果与某个WHEN子句匹配,则执行相应的操作并返回该结果。如果没有匹配的条件,则执行ELSE子句中的操作并返回该结果。 ELSEIF语句用于在多个条件之间进行逐个判断,根据满足的条件执行相应的操作。语法如下: ```sql CASE WHEN <condition1> THEN <result1> ELSEIF <condition2> THEN <result2> ... ELSE <result> END ``` 在这个语法中,如果没有满足第一个条件的情况,那么会检查第二个条件,如果满足,则执行相应的操作并返回结果。如果所有条件都不满足,则执行ELSE子句中的操作并返回该结果。 ELSE语句用于在没有满足任何条件时的默认操作。如果CASE WHEN或ELSEIF语句中没有匹配的条件,那么就会执行ELSE子句中的操作并返回该结果。语法如下: ```sql CASE WHEN <condition1> THEN <result1> WHEN <condition2> THEN <result2> ... ELSE <result> END_LAMBDA ``` 请注意,以上是使用DB2CASE WHEN、ELSEIF和ELSE的基本语法。实际使用时,可能需要根据你的具体需求进行调整和扩展。此外,CASE语句还可以与其他SQL函数和表达式结合使用,以实现更复杂的条件逻辑和数据转换。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值