SQL中 decode 函式簡介

2022-09-28 20:00:13 字數 2012 閱讀 3022

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(型)和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_cha程式設計客棧r(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 未能與任何乙個值匹配時,函式返回的預設值。

本文標題: sql中 decode()函式簡介

本文位址: /shujuku/mssql/143725.html

SQL中 decode 函式簡介

今天看別人的sql時看這裡面還有decode 函式,以前從來沒接觸到,上網查了一下,還挺好用的乙個函式,寫下來希望對朋友們有幫助哈!decode 函式簡介 主要作用 將查詢結果翻譯成其他值 即以其他形式表現出來,以下舉例說明 使用方法 select decode columnname,值1,翻譯值1...

SQL中 decode 函式簡介

decode函式,是oracle公司的sql 軟體oracle pl sql所提供的特有函式計算方式,以其簡潔的運算方式,可控的資料模型和靈活的格式轉換而聞名。今天看別人的sql時看這裡面還有decode 函式,以前從來沒接觸到,上網查了一下,還挺好用的乙個函式,寫下來希望對朋友們有幫助哈!deco...

SQL中 decode 函式簡介

原文sql中 decode 函式簡介 使用方法 select decode columnname,值1,翻譯值1,值2,翻譯值2,值n,翻譯值n,預設值 from talbename where 其中columnname為要選擇的table中所定義的column,含 釋 decode 條件,值1,翻...