當前位置:首頁 » 編程語言 » sql的decode

sql的decode

發布時間: 2025-01-17 01:01:01

1. 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
未能與任何一個值匹配時,函數返回的默認值。

2. 請問SQL中decode函數的用法

DECODE函數是ORACLE PL/SQL是功能強大的函數之一,還只有ORACLE公司的SQL提供了此函數,其他資料庫廠商的SQL實現還沒有此功能。

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

(2)sql的decode擴展閱讀:

DECODE(value, if1, then1, if2,then2, if3,then3, . . . else )

Value 代表某個表的任何類型的任意列或一個通過計算所得的任何結果。當每個value值被測試,如果value的值為if1,Decode 函數的結果是then1;如果value等於if2,Decode函數結果是then2;等等。事實上,可以給出多個if/then 配對。如果value結果不等於給出的任何配對時,Decode 結果就返回else 。

需要注意的是,這里的if、then及else 都可以是函數或計算表達式。

熱點內容
asm源碼編譯 發布:2025-01-17 03:54:24 瀏覽:287
如何配置svi介面的ip地址 發布:2025-01-17 03:48:09 瀏覽:44
微軟怎麼解壓縮文件 發布:2025-01-17 03:43:06 瀏覽:203
有沒有手機可以用的java編譯器 發布:2025-01-17 03:38:56 瀏覽:542
手把手教你學c語言版 發布:2025-01-17 03:38:52 瀏覽:781
最優化遺傳演算法 發布:2025-01-17 03:35:24 瀏覽:547
四代飛度家用需要加裝哪些配置 發布:2025-01-17 03:34:28 瀏覽:877
安卓手機貓和老鼠怎麼換號 發布:2025-01-17 03:23:58 瀏覽:469
安卓系統怎麼下蝙蝠 發布:2025-01-17 03:20:07 瀏覽:19
加密解密文件 發布:2025-01-17 03:16:32 瀏覽:83