oracle decode用法 case when then else end

含义解释:
decode(条件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值)

该函数的含义如下:
IF 条件=值1 THEN
    RETURN(翻译值1)
ELSIF 条件=值2 THEN
    RETURN(翻译值2)
    ......
ELSIF 条件=值n THEN
    RETURN(翻译值n)
ELSE
    RETURN(缺省值)
END IF
decode(字段或字段的运算,值1,值2,值3)

       这个函数运行的结果是,当字段或字段的运算的值等于值1时,该函数返回值2,否则返回值3
当然值1,值2,值3也可以是表达式,这个函数使得某些sql语句简单了许多

使用方法:
1、比较大小
select decode(sign(变量1-变量2),-1,变量1,变量2) from dual; --取较小值
sign()函数根据某个值是0、正数还是负数,分别返回0、1、-1
例如:
变量1=10,变量2=20
则sign(变量1-变量2)返回-1,decode解码结果为“变量1”,达到了取较小值的目的。

2、此函数用在SQL语句中,功能介绍如下:

Decode函数与一系列嵌套的 IF-THEN-ELSE语句相似。base_exp与compare1,compare2等等依次进行比较。如果base_exp和 第i 个compare项匹配,就返回第i 个对应的value 。如果base_exp与任何的compare值都不匹配,则返回default。每个compare值顺次求值,如果发现一个匹配,则剩下的compare值(如果还有的话)就都不再求值。一个为NULL的base_exp被认为和NULL compare值等价。如果需要的话,每一个compare值都被转换成和第一个compare 值相同的数据类型,这个数据类型也是返回值的类型。

Decode函数在实际开发中非常的有用

结合Lpad函数,如何使主键的值自动加1并在前面补0
select LPAD(decode(count(记录编号),0,1,max(to_number(记录编号)+1)),14,'0') 记录编号 from tetdmis

eg:

select decode(dir,1,0,1) from a1_interval

dir 的值是1变为0,是0则变为1

比如我要查询某班男生和女生的数量分别是多少?

通常我们这么写:

select count(*) from 表 where 性别 = 男;

select count(*) from 表 where 性别 = 女;

要想显示到一起还要union一下,太麻烦了

用decode呢,只需要一句话

select decode(性别,男,1,0),decode(性别,女,1,0) from 表

 

 

3,order by对字符列进行特定的排序

大家还可以在Order by中使用Decode。

例:表table_subject,有subject_name列。要求按照:语、数、外的顺序进行排序。这时,就可以非常轻松的使用Decode完成要求了。

select * from table_subject order by decode(subject_name, '语文', 1, '数学', 2, , '外语',3)

 

 

 

case when then else end   =========================================================

两种语法模式:

(1):只有一个分支

     CASE
        WHEN 条件  THEN 结果1
        ELSE            结果2
      END


(2):支持多种分支

     CASE 表达式1
        WHEN 表达式2   THEN 结果1
        ELSE            结果2
   END

上面的WHEN可以重复多次,

 

===================

 

简单示例:

  1. select    
  2.     case when 1 = 1  
  3.     then 1  
  4.     else 2  
  5.     end;  
  1. select    
  2.     case 2  
  3.     when 1 then 1  
  4.     when 2 then 2  
  5.     when 3 then 3  
  6.     else 4  
  7.     end;  

============================

下面详细的各举几个例子,这些例子可以用于ESQL和交互式的SQL中
eg1:处理被0除

[java] view plain copy
  1. SELECT   
  2. CASE   
  3. WHEN fileld1=0 THEN 0  
  4. ELSE fileld2/field1  
  5. END  
  6. FROM  FILE  


eg2:字段值对应转换

[java] view plain copy
 
  1. SELECT ORDNO,CUSNAM,SHIPDATE,CASE  
  2.                 WHEN SHIPDATE<CURDATE()  THEN 'OVERDUE'  
  3.                 WHEN SHIPDATE=CURDATE()  THEN 'PROCESSING'  
  4.                 WHEN SHIPDATE>;CURDATE()  THEN 'ACTIVE'  
  5.               END  
  6. FROM FILE  


eg3:获取月份的名字:上面的例子

[java] view plain copy
 
  1. SELECT ORDNO,CUSNO,  
  2.    CASE  MONTH(SHIPDATE)  
  3.    WHEN  '01'   THEN 'Jan'  
  4.    WHEN  '02'   THEN 'Feb'  
  5.    WHEN  '03'   THEN 'Mar'  
  6.    WHEN  '04'   THEN 'Apr'  
  7.    WHEN  '05'   THEN 'May'  
  8.    WHEN  '06'   THEN 'Jun'  
  9.    WHEN  '07'   THEN 'Jul'  
  10.    WHEN  '08'   THEN 'Aug'  
  11.    WHEN  '09'   THEN 'Sep'  
  12.    WHEN  '10'   THEN 'Oct'  
  13.    WHEN  '11'   THEN  'Nov'  
  14.    WHEN  '12'   THEN  'Dec'  
  15.    END  
  16. FROM FILE  

===================

 

CASE很好用,不仅SELECT可以用,UPATE里面也蛮灵

以上是关于查询的  下面再来个 update的

 

贴代码直观:

[c-sharp] view plain copy
 
  1. UPDATE properities  
  2. SET   taxrate=  
  3.    CASE   
  4.        WHEN area<10000 THEN 0.05  
  5.        WHEN area<20000 THEN 0.07  
  6.        ELSE 0.09  
  7.    END  

 

posted on 2017-05-09 08:16  ceng006  阅读(453)  评论(0)    收藏  举报

导航