麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 數(shù)據(jù)庫 > Oracle > 正文

oracle中decode函數(shù)的使用方法示例

2024-08-29 14:00:52
字體:
供稿:網(wǎng)友

decode的幾種用法

1:使用decode判斷字符串是否一樣

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

含義為
IF 條件=值1 THEN
    RETURN(value 1)

ELSIF 條件=值2 THEN
    RETURN(value 2)
    ......

ELSIF 條件=值n THEN
    RETURN(value 3)
ELSE
    RETURN(default)
END IF

sql測試

select empno,decode(empno,7369,'smith',7499,'allen',7521,'ward',7566,'jones','unknow') as name from emp where rownum<=10

輸出結(jié)果

7369 smith7499 allen7521 ward7566 jones7654 unknow7698 unknow7782 unknow7788 unknow7839 unknow7844 unknow

2:使用decode比較大小

select decode(sign(var1-var2),-1,var 1,var2) from dual

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

sql測試

select decode(sign(100-90),-1,100,90) from dual

輸出結(jié)果

90

100-90=10>0 則會返回1,所以decode函數(shù)最終取值為90

反正

select decode(sign(100-90),1,100,90) from dual

輸出結(jié)果

100

100-90=10>0返回1,判斷結(jié)果為1,返回第一個變量100,最終輸出結(jié)果為100

3:使用decode函數(shù)分段

工資大于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

輸出結(jié)果

SMITH  800  low salALLEN 1600 low salWARD 1250 low salJONES 2975 low salMARTIN 1250 low salBLAKE  2850 low salCLARK 2450 low salSCOTT 3000 mid salKING 5000 high salTURNER 1500 low salADAMS 1100 low salJAMES 950     low salFORD 3000 mid salMILLER 1300 low sal

4:利用decode實現(xiàn)表或者試圖的行列轉(zhuǎn)換

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

輸出結(jié)果如下

SMITH ALLEN WARD  JONES MARTIN 800 1600  1250    2975    1250

5:使用decode函數(shù)來使用表達(dá)式來搜索字符串

decode (expression, search_1, result_1, search_2, result_2, ...., search_n, result_n, default)

decode函數(shù)比較表達(dá)式和搜索字,如果匹配,返回結(jié)果;如果不匹配,返回default值;如果未定義default值,則返回空值。

sql測試

SELECT   ENAME,  SAL,  DECODE(INSTR(ENAME, 'S'),      0,      '不含有s',      '含有s') AS INFOFROM  EMP

輸出結(jié)果

SMITH 800      含有sALLEN 1600  不含有sWARD 1250  不含有sJONES 2975   含有sMARTIN 1250   不含有sBLAKE 2850   不含有sCLARK 2450   不含有sSCOTT 3000  含有sKING 5000  不含有sTURNER 1500  不含有sADAMS 1100  含有sJAMES 950       含有sFORD 3000  不含有sMILLER 1300  不含有s

Decode函數(shù)在實際開發(fā)中非常的有用

結(jié)合Lpad函數(shù),如何使主鍵的值自動加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變?yōu)?,是0則變?yōu)?

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

通常我們這么寫:
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;

總結(jié)

以上就是本文關(guān)于oracle中decode函數(shù)的使用方法示例的全部內(nèi)容,希望對大家有所幫助。感謝朋友們對本站的支持!


注:相關(guān)教程知識閱讀請移步到oracle教程頻道。
發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 欧美日韩亚洲一区二区三区 | 91精品中文字幕 | 一级黄色免费电影 | 黄色av.com | 制服丝袜日日夜夜 | 一级免费在线视频 | 色人阁导航 | 欧美大胆xxxx肉体摄影 | 亚洲天堂ww | 精品久久久久久综合日本 | 中文字幕h | 国产精品久久久av | 色女人在线 | 成人国产精品一区 | 偷偷草网站 | 久久亚洲美女视频 | 精品国产一区二区三区成人影院 | 毛片天天看| 免费看一级毛片欧美 | 久久影院一区二区三区 | 欧美福利视频一区二区 | 成人福利视频 | 中文字幕在线观看精品 | 他也色在线视频 | 成人午夜看片 | 中国国语毛片免费观看视频 | 在线播放h | 中文国产在线视频 | 亚洲第一成人在线观看 | 亚洲第一成人久久网站 | 久久久久九九九女人毛片 | 欧美一区二区三区不卡免费观看 | 一区二区三区欧美在线 | 久草导航| 国产精品久久久乱弄 | 欧美精品在线视频观看 | 成人免费看视频 | 91午夜免费视频 | 久久精品国产清自在天天线 | 黑人日比视频 | 欧美激情精品久久久久久久久久 |