PL/SQL中decode函數簡介

今天看別人的SQL時看這裏面還有decode()函數,之前歷來沒接觸到,上網查了一下,還挺好用的一個函數,寫下來但願對朋友們有幫助哈!html

 

      

 

 decode()函數簡介:ide

主要做用:將查詢結果翻譯成其餘值(即以其餘形式表現出來,如下舉例說明);函數

使用方法:post

Select decode(columnname,值1,翻譯值1,值2,翻譯值2,...值n,翻譯值n,缺省值)翻譯

From talbenamecode

Where …htm

其中columnname爲要選擇的table中所定義的column,blog

·含義解釋:ip

decode(條件,值1,翻譯值1,值2,翻譯值2,...值n,翻譯值n,缺省值)的理解以下:get

if (條件==值1)

 then    

return(翻譯值1)

elsif (條件==值2)

then    

return(翻譯值2)    

......

elsif (條件==值n)

 then    

return(翻譯值n)

else    

return(缺省值)

end if

注:其中缺省值能夠是你要選擇的column name 自己,也能夠是你想定義的其餘值,好比Other等;

舉例說明:

現定義一table名爲output,其中定義兩個column分別爲monthid(var型)和sale(number型),若sale值=1000時翻譯爲D,=2000時翻譯爲C,=3000時翻譯爲B,=4000時翻譯爲A,如是其餘值則翻譯爲Other;

SQL以下:

Select monthid , decode (sale,1000,'D',2000,'C',3000,'B',4000,'A',’Other’) sale from output

特殊狀況:

若只與一個值進行比較

Select monthid ,decode(sale, NULL,‘---’,sale) sale from output

另:decode中可以使用其餘函數,如nvl函數或sign()函數等;

NVL(EXPR1,EXPR2)

若EXPR1是NULL,則返回EXPR2,不然返回EXPR1.

SELECT NAME,NVL(TO_CHAR(COMM),'NOT APPLICATION') FROM TABLE1;

若是用到decode函數中就是

select monthid,decode(nvl(sale,6000),6000,'NG','OK') from output

 

sign()函數根據某個值是0、正數仍是負數,分別返回0、一、-1,

若是取較小值就是

select monthid,decode(sign(sale-6000),-1,sale,6000) from output,即達到取較小值的目的。

原文連接:http://www.cnblogs.com/freespider/archive/2010/08/09/1795977.html

相關文章
相關標籤/搜索