DB2 使用Case语句

我们在编写SQL语句时,常常遇到希望SQL能够按条件执行的情况。这里的条件不是指Where子句中的条件,而是指让DB2根据条件执行SQL的语句块。大多数情况下我们可以使用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

还有一些其他的例子:

例如,我们希望从员工表中查出员工的工资情况,如果小于20000,则标志为low2000050000间为middle,否则为high。一般大家会想到先取出工资数据然后在Java代码中做判断,但我们也可以在SQL中完成上述操作。如下例:

select empno, sex, salary,
case
 when salary < 20000 then 'low'
 when salary >=20000 and salary <50000 then 'middle'
 else 'high'
end as salaryclass
from employee

类似的,如果想在SQL语句中把性别翻译成文字,也可以用case实现,注意这两条SQL语句使用了不同的case表达式写法:

select empno,
case sex
 when 'M' then 'male'
 when 'F' then 'female'
 else 'invalid'
end,
salary
from employee


Case不但能够在Select子句中使用,在From子句和Where子句中同样可以使用。下面是在Where子句中使用的一个例子:

select empno, sex, age
from employee
where
case sex
 when 'M' then 55
 when 'F' then 50
end > age














  • 2
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值