- 论坛徽章:
- 0
|
在db2中case怎么用?
上面说的不细,详细的说一下:
两种语法模式:
(1):CASE
WHEN 条件 THEN 结果1
ELSE 结果2
END
(2):CASE 表达式1
WHEN 表达式2 THEN 结果1
ELSE 结果2
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
|
|