主頁 > 知識庫 > SQL中 decode()函數(shù)簡介

SQL中 decode()函數(shù)簡介

熱門標(biāo)簽:安卡拉地圖標(biāo)注app 400電話辦理泰安 電話機器人怎么代理商 家庭農(nóng)場地圖標(biāo)注名稱怎樣起名 互聯(lián)網(wǎng)電話外呼系統(tǒng) 電銷需要外呼系統(tǒng)嗎 我要地圖標(biāo)注數(shù)量有限制嗎 零成本地圖標(biāo)注賺錢 千呼電話機器人可以試用嗎

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

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

decode()函數(shù)簡介:

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

使用方法:

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等;

舉例說明:

現(xiàn)定義一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

特殊情況:

若只與一個值進(jìn)行比較

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

另:decode中可使用其他函數(shù),如nvl函數(shù)或sign()函數(shù)等;

NVL(EXPR1,EXPR2)

若EXPR1是NULL,則返回EXPR2,否則返回EXPR1.

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

如果用到decode函數(shù)中就是

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

sign()函數(shù)根據(jù)某個值是0、正數(shù)還是負(fù)數(shù),分別返回0、1、-1,

如果取較小值就是

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

小結(jié):

作用:將輸入數(shù)值與函數(shù)中的參數(shù)列表相比較,根據(jù)輸入值返回一個對應(yīng)值。函數(shù)的參數(shù)列表是由若干數(shù)值及其對應(yīng)結(jié)果值組成的若干序偶形式。當(dāng)然,假如未能與任何一個實參序偶匹配成功,則函數(shù)也有默認(rèn)的返回值。 區(qū)別于SQL的其它函數(shù),DECODE函數(shù)還能識別和操作空值。

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

control _value試圖處理的數(shù)值。DECODE函數(shù)將該數(shù)值與后面的一系列的偶序相比較,以決定返回值。 value1是一組成序偶的數(shù)值。假如輸入數(shù)值與之匹配成功,則相應(yīng)的結(jié)果將被返回。對應(yīng)一個空的返回值,可以使用要害字NULL于之對應(yīng) result1 是一組成序偶的結(jié)果值。 default_result 未能與任何一個值匹配時,函數(shù)返回的默認(rèn)值。

您可能感興趣的文章:
  • SQL中object_id函數(shù)的用法
  • Sql Server 字符串聚合函數(shù)
  • SQL Server 排序函數(shù) ROW_NUMBER和RANK 用法總結(jié)
  • sql convert函數(shù)使用小結(jié)
  • sqlserver substring函數(shù)使用方法小結(jié)
  • sqlserver CONVERT()函數(shù)用法小結(jié)
  • SQLSERVER ISNULL 函數(shù)與判斷值是否為空的sql語句
  • SQL的SUBSTR()函數(shù)使用介紹
  • sql format()函數(shù)的用法及簡單實例
  • SQL查詢排名函數(shù)實例
  • SQL中位數(shù)函數(shù)實例

標(biāo)簽:池州 來賓 文山 大同 濱州 新鄉(xiāng) 東營 黃山

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《SQL中 decode()函數(shù)簡介》,本文關(guān)鍵詞  SQL,中,decode,函數(shù),簡介,SQL,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請?zhí)峁┫嚓P(guān)信息告之我們,我們將及時溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《SQL中 decode()函數(shù)簡介》相關(guān)的同類信息!
  • 本頁收集關(guān)于SQL中 decode()函數(shù)簡介的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章