DB2中case的用法

09年05月15日

 

两种语法模式:

(1):CASE
       WHEN 条件  THEN 结果1

       WHEN 条件  THEN 结果2
       ELSE            结果3
     END

(2):CASE 表达式1
       WHEN 表达式2   THEN 结果1

       WHEN 表达式2   THEN 结果2
       ELSE            结果3
    END

 

 

 

上面的WHEN可以重复多次,就像C中的SWITCH ..CASE的表达
下面详细的各举几个例子,这些例子可以用于ESQL和交互式的SQL中

eg1:处理被0除
SELECT
CASE
WHEN fileld1=0 THEN 0
ELSE fileld2/field1
END
FROM  FILE

eg2:字段值对应转换
SELECT ORDNO,CUSNAM,SHIPDATE,CASE
               WHEN SHIPDATE<CURDATE()  THEN ‘OVERDUE’
               WHEN SHIPDATE=CURDATE()  THEN ‘PROCESSING’
               WHEN SHIPDATE>CURDATE()  THEN ‘ACTIVE’
             END
FROM FILE

 

eg3:获取月份的名字:上面的例子
SELECT ORDNO,CUSNO,
  CASE  MONTH(SHIPDATE)
  WHEN  ‘01′   THEN ‘Jan’
  WHEN  ‘02′   THEN ‘Feb’
  WHEN  ‘03′   THEN ‘Mar’
  WHEN  ‘04′   THEN ‘Apr’
  WHEN  ‘05′   THEN ‘May’
  WHEN  ‘06′   THEN ‘Jun’
  WHEN  ‘07′   THEN ‘Jul’
  WHEN  ‘08′   THEN ‘Aug’
  WHEN  ‘09′   THEN ‘Sep’
  WHEN  ‘10′   THEN ‘Oct’
  WHEN  ‘11′   THEN  ‘Nov’
  WHEN  ‘12′   THEN  ‘Dec’
  END
FROM FILE






相关文章:

  1. delphi关键字详解
  2. db2中是否有类似于oracle中nvl的函数使用总结
  3. 使用DB2必须了解的几个知识点
  4. DB2中rownumber(rowno)
  5. Eclipse 3.5 反编译工具安装(jad jadclipse)



  • 原文链接: http://www.astesys.com/database/db2/324.html
  • 转载文章请注明: 爱思特
  • Tags: , 分类: DB2

    发表评论