日本免费高清视频-国产福利视频导航-黄色在线播放国产-天天操天天操天天操天天操|www.shdianci.com

學無先后,達者為師

網站首頁 編程語言 正文

Oracle進階DECODE函數使用詳解_oracle

作者:sdut菜鳥 ? 更新時間: 2022-03-20 編程語言

DECODE含義

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

這個是decode的表達式,具體的含義解釋為:

IF 條件=值1 THEN
    RETURN(翻譯值1)
ELSIF 條件=值2 THEN
    RETURN(翻譯值2)
    ......
ELSIF 條件=值n THEN
    RETURN(翻譯值n)
ELSE
    RETURN(缺省值)
END IF

DECODE的用法

這里主要說的就是decode的用法,在很多時候這個函數還是很有用的。

1.翻譯值

數據截圖:

需求:查詢出的數據,1表示男生,2表示女生

select t.id,
       t.name,
       t.age,
       decode(t.sex, '1', '男生', '2', '女生', '其他') as sex
  from STUDENT2 t

結果:

2.decode比較大小

說明:sign(value)函數會根據value的值為0,正數,負數,分別返回0,1,-1

數據:

需求:年齡在20以上的顯示20以上,20以下的顯示20以下,20的顯示正好20

select t.id,
       t.name,
       t.age,
       decode(sign(t.age - 20),
              1,
              '20以上',
              -1,
              '20以下',
              0,
              '正好20',
              '未知') as sex
  from STUDENT2 t

結果:

3.decode分段

數據暫無

需求:工資大于5000為高薪,工資介于3000到5000為中等,工資小于3000為底薪

select name,
       sal,
       decode(sign(sal - 5000),
              1,
              '高薪',
              0,
              '高薪',
              -1,
              decode(sign(sal - 3000), 1, '中等', 0, '中等', -1, '低薪')) as salname
  from person;

結果暫無

4.搜索字符串

數據:

需求:找到含有三的姓名

select t.id,
       decode(instr(t.name, '三'), 0, '姓名不含有三', '姓名含有三') as name,
       t.age,
       t.sex
  from STUDENT2 t

結果:

5.判斷是否為空

數據:

需求:性別為空顯示“暫無數據”,不為空原樣輸出

select t.id,
       t.name,
       t.age,
       decode(t.sex,NULL,'暫無數據',t.sex) as sex
  from STUDENT2 t

結果:

總結:decode在書寫sql的時候還是挺有用的,常用的應該是1和5了吧(我猜的,因為我就是經常用這兩種)

原文鏈接:https://blog.csdn.net/sdut406/article/details/82795585

欄目分類
最近更新