Oracle 中 decode 函數用法


含義解釋:

decode (條件,值1,返回值1,值2,返回值2,...值n,返回值n,缺省值)

該函數的含義如下:

IF    條件=值1   THEN 

                RETURN   返回值1

ELSEIF 條件=值2   THEN

                     RETURN  返回值2

        .....

ELSEIF  條件=值n   THEN

                       RETURN 返回值n

 

ELSE

                       RETURN 缺省值

END IF

decode (字段或字段的運算,值1,值2,值3)

      這個函數運行的結果是,當字段或字段運算的值等於 值1 時,該函數返回 值2,否則返回 值3

 當然 值1,值2,值3也可以是表達式,這個函數使得某些sql語句簡化了許多。

      使用方法:

1、比較大小

select decode (sign(變量1 - 變量2),-1,變量1,變量2))  from dual;--取較小值

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

例如:

變量1=10,變量2=20

則sign(變量1-變量2) 返回-1,decode 解碼結果是“變量1”,達到了取小值的目的。

2、此函數用在SQL語句中,功能介紹如下:

Decode函數與一系列嵌套的 IF-THEN-ELSE語句相似。base_exp與compare1,compare2等等依次進行比較。如果base_exp和 第i 個compare項匹配,就返回第i 個對應的value 。如果base_exp與任何的compare值都不匹配,則返回default。每個compare值順次求值,如果發現一個匹配,則剩下的compare值(如果還有的話)就都不再求值。一個為NULL的base_exp被認為和NULL compare值等價。如果需要的話,每一個compare值都被轉換成和第一個compare 值相同的數據類型,這個數據類型也是返回值的類型。

 

 

 

Decode函數在實際開發中非常的有用

結合Lpad函數,如何使主鍵的值自動加1並在前面補0
select LPAD(decode(count(記錄編號),0,1,max(to_number(記錄編號)+1)),14,'0') 記錄編號 from tetdmis

 

 

eg:

 

select decode(dir,1,0,1) from a1_interval

dir 的值是1變為0,是0則變為1

 

比如我要查詢某班男生和女生的數量分別是多少?

 

通常我們這么寫:

select count(*) from 表 where 性別 = 男;

select count(*) from 表 where 性別 = 女;

要想顯示到一起還要union一下,太麻煩了

用decode呢,只需要一句話

select sum(decode(性別,男,1,0)),sum(decode(性別,女,1,0)) from 表

eg:

select sum(decode(siteno,'LT',1,0)),sum(decode(siteno,'SZ',1,0)) from facd605;

select sum(case siteno when 'LT' then 1 else 0 end),sum(case siteno when 'SZ' then 1 else 0 end) from facd605;

參照來源:https://www.cnblogs.com/vinsonLu/p/3512526.html


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM