當前位置:編程學習大全網 - 圖片素材 - SQL中 decode()函數簡介

SQL中 decode()函數簡介

DECODE函數,是ORACLE公司的SQL軟件ORACLE

PL/SQL所提供的特有函數計算方式,以其簡潔的運算方式,可控的數據模型和靈活的格式轉換而聞名。

今天看別人的SQL時看這裏面還有decode()函數,以前從來沒接觸到,上網查了壹下,還挺好用的壹個函數,寫下來希望對朋友們有幫助哈!

decode()函數簡介:

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

使用方法:

Select

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

From

talbename

Where

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

·含義解釋:

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

註:其中缺省值可以是妳要選擇的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、-1,

如果取較小值就是

select

monthid,decode(sign(sale-6000),-1,sale,6000)

from

output,即達到取較小值的目的。

小結:

作用:將輸入數值與函數中的參數列表相比較,根據輸入值返回壹個對應值。函數的參數列表是由若幹數值及其對應結果值組成的若幹序偶形式。當然,假如未能與任何壹個實參序偶匹配成功,則函數也有默認的返回值。

區別於SQL的其它函數,DECODE函數還能識別和操作空值。

語法:DECODE(control_value,value1,result1[,value2,result2…][,default_result]);

control

_value試圖處理的數值。DECODE函數將該數值與後面的壹系列的偶序相比較,以決定返回值。

value1是壹組成序偶的數值。假如輸入數值與之匹配成功,則相應的結果將被返回。對應壹個空的返回值,可以使用要害字NULL於之對應

result1

是壹組成序偶的結果值。

default_result

未能與任何壹個值匹配時,函數返回的默認值。

  • 上一篇:情侶網名超拽
  • 下一篇:中國比特幣合法嗎?
  • copyright 2024編程學習大全網