DECODE函數簡介

在上一篇bolg中講到ORACLE優化的時候提到DECODE()函數,之前本身用的也比較少,上網查了一下,還挺好用的一個函數,寫下來但願對朋友們有幫助哈!html

http://www.javashuo.com/article/p-qxhumhlr-bv.html ORACLE查詢優化sql

1:使用decode判斷字符串是否同樣數據庫

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

使用方法:函數

SELECT DECODE(columnname,值1,翻譯值1,值2,翻譯值2,...值n,翻譯值n,缺省值)測試

FROM talbename優化

WHERE…spa

其中columnname爲要選擇的table中所定義的column.net

含義解釋:翻譯

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,

若是取較小值就是

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

  2:使用decode比較大小
select decode(sign(var1-var2),-1,var 1,var2) from dual
sign()函數根據某個值是0、正數仍是負數,分別返回0、一、-1
sql測試
select decode(sign(100-90),-1,100,90) from dual
輸出結果
90
100-90=10>0 則會返回1,因此decode函數最終取值爲90
反正
select decode(sign(100-90),1,100,90) from dual
輸出結果
100
100-90=10>0返回1,判斷結果爲1,返回第一個變量100,最終輸出結果爲100

  3:使用decode函數分段
工資大於5000爲高薪,工資介於3000到5000爲中等,工資小於3000爲低薪
sql測試
SELECT 
    ename,sal,
    DECODE(SIGN(sal - 5000),
            1,
            'high sal',
            0,
            'high sal',
            - 1,
            DECODE(SIGN(sal - 3000),
                    1,
                    'mid sal',
                    0,
                    'mid sal',
                    - 1,
                    DECODE(SIGN(sal - 1000),
                            1,
                            'low sal',
                            0,
                            'low sal',
                            - 1,
                            'low sal')))
FROM
    emp

輸出結果
SMITH   800   low sal
ALLEN 1600 low sal
WARD 1250 low sal
JONES 2975 low sal
MARTIN 1250 low sal
BLAKE   2850 low sal
CLARK 2450 low sal
SCOTT 3000 mid sal
KING  5000 high sal
TURNER 1500 low sal
ADAMS 1100 low sal
JAMES 950         low sal
FORD 3000 mid sal
MILLER 1300 low sal

4:利用decode實現表或者試圖的行列轉換

sql測試
SELECT 
       SUM(DECODE(ENAME,'SMITH',SAL,0))  SMITH,
       SUM(DECODE(ENAME,'ALLEN',SAL,0))  ALLEN,
       SUM(DECODE(ENAME,'WARD',SAL,0))   WARD,
       SUM(DECODE(ENAME,'JONES',SAL,0))  JONES,
       SUM(DECODE(ENAME,'MARTIN',SAL,0)) MARTIN FROM EMP
輸出結果以下
SMITH  ALLEN  WARD   JONES  MARTIN
  800  1600   1250       2975       1250

5:使用decode函數來使用表達式來搜索字符串
decode (expression, search_1, result_1, search_2, result_2, ...., search_n, result_n, default)
decode函數比較表達式和搜索字,若是匹配,返回結果;若是不匹配,返回default值;若是未定義default值,則返回空值。
sql測試
SELECT 
    ENAME,
    SAL,
    DECODE(INSTR(ENAME, 'S'),
            0,
            '不含有s',
            '含有s') AS INFO
FROM
    EMP
輸出結果
SMITH 800           含有s
ALLEN 1600   不含有s
WARD 1250   不含有s
JONES 2975    含有s
MARTIN 1250    不含有s
BLAKE 2850    不含有s
CLARK 2450    不含有s
SCOTT 3000   含有s
KING 5000   不含有s
TURNER 1500   不含有s
ADAMS 1100   含有s
JAMES 950            含有s
FORD 3000   不含有s
MILLER 1300   不含有s

原文取自:

http://www.javashuo.com/article/p-dkdyfavi-cz.html

https://blog.csdn.net/weeknd/article/details/71157044

相關文章
相關標籤/搜索