永夜海 发表于 2016-11-16 10:25:45

【菜鸟学习记】DB2中case的使用

今天工作中涉及到SQL,用到case when,但是DB2没用过,语法也不清楚,因此网上搜搜,总算完成了任务。下面来小结下语法使用:

两种语法模式:
(1):CASE
      WHEN 条件THEN 结果1
      ELSE            结果2
      END
(2):CASE 表达式1
      WHEN 表达式2   THEN 结果1
      ELSE            结果2
   END

上面(1)中的WHEN可以重复多次,参照eg2,就像C中的SWITCH ..CASE的表达

下面详细的各举几个例子,这些例子可以用于ESQL和交互式的SQL中
eg1:处理被0除
SELECT
CASE
WHEN fileld1=0 THEN 0
ELSE fileld2/field1
END
FROMFILE

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:获取月份的名字:对应上面的模式(2)
SELECT ORDNO,CUSNO,
   CASEMONTH(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]
查看完整版本: 【菜鸟学习记】DB2中case的使用