decode的用法是
DECODE(control_value,value1,result1[,value2,result2…][,default_result]);
参数说明:
control _value
试图处理的数值。可以是数据库中表的某一列,DECODE函数将该数值与后面的一系列的偶序相比较,以决定返回值。
value1
是一组成序偶的数值。如果输入数值与之匹配成功,则相应的结果将被返回。对应一个空的返回值,可以使用关键字NULL于之对应
result1
是一组成序偶的结果值。
default_result
未能与任何一个值匹配时,函数返回的默认值。
SELECT decode(sign(to_date('2008-05-01', 'yyyy-MM-dd') - to_date('2008-03-01', 'yyyy-MM-dd')), 1, to_date('2008-05-02', 'yyyy-MM-dd'), to_date('2008-03-02', 'yyyy-MM-dd')) FROM dual
另外一种方法就是CASE WHEN THEN END
本人比较喜欢这种,因为有时候判断的内容比较长,CASE WHEN的结构更加清晰。
select case when to_date('2008-05-01', 'yyyy-MM-dd') >= to_date('2008-03-01', 'yyyy-MM-dd') then to_date('2008-05-01', 'yyyy-MM-dd') else to_date('2008-03-01', 'yyyy-MM-dd') end from dual
还有一种CASE WHEN用法
CASE sex WHEN '1' THEN '男' WHEN '2' THEN '女' ELSE '其他' END
另外,在WHERE语句里面使用CASE WHEN:
SELECT T2.*, T1.* FROM T1, T2 WHERE (CASE WHEN T2.COMPARE_TYPE = 'A' AND T1.SOME_TYPE LIKE 'NOTHING%' THEN 1 WHEN T2.COMPARE_TYPE != 'A' AND T1.SOME_TYPE NOT LIKE 'NOTHING%' THEN 1 ELSE 0 END) = 1
在存储过程中使用的最多的是IF判断语句。
在Oracle中,IF语句分为三种形式:
IF A>B THEN B=A ; END IF; IF A>B THEN B=A; ELSE A=B; END IF; IF A>B THEN B=1 ; ELSIF A=B ; THEN B= 0; ELSE A= 1; END IF;
要注意的是。
还可以加上begin....end,本情况只适用于if 嵌套情况,如
if .... then begin elsif ... then end if;