欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Oracle 中 decode 函數(shù)用法

 更新時間:2017年10月25日 10:37:41   作者:qin_yaping  
這篇文章主要介紹了Oracle 中 decode 函數(shù)用法的相關(guān)資料,需要的朋友可以參考下

含義解釋:

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

該函數(shù)的含義如下:

IF 條件=值1 THEN
    RETURN(翻譯值1)
ELSIF 條件=值2 THEN
    RETURN(翻譯值2)
    ......
ELSIF 條件=值n THEN
    RETURN(翻譯值n)
ELSE
    RETURN(缺省值)
END IF
decode(字段或字段的運算,值1,值2,值3)

      這個函數(shù)運行的結(jié)果是,當(dāng)字段或字段的運算的值等于值1時,該函數(shù)返回值2,否則返回值3
 當(dāng)然值1,值2,值3也可以是表達式,這個函數(shù)使得某些sql語句簡單了許多

使用方法:

1、比較大小

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

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

例如:

變量1=10,變量2=20

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

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

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

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

總結(jié)

以上所述是小編給大家介紹的Oracle 中 decode 函數(shù)用法,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!

相關(guān)文章

  • Oracle中的序列SEQUENCE詳解

    Oracle中的序列SEQUENCE詳解

    本文詳細講解了Oracle中的序列SEQUENCE,文中通過示例代碼介紹的非常詳細。對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2022-05-05
  • 一些Oracle數(shù)據(jù)庫中的查詢優(yōu)化建議綜合

    一些Oracle數(shù)據(jù)庫中的查詢優(yōu)化建議綜合

    這篇文章主要介紹了一些Oracle數(shù)據(jù)庫中的查詢優(yōu)化建議綜合,包括in和not in的使用等一些細節(jié)上的使用建議,需要的朋友可以參考下
    2016-01-01
  • oracle中if/else的三種實現(xiàn)方式詳解

    oracle中if/else的三種實現(xiàn)方式詳解

    本文給大家介紹了oracle中if/else的三種實現(xiàn)方式及注意事項,非常不錯,具有參考借鑒價值,需要的朋友參考下吧
    2017-10-10
  • 快速查出Oracle數(shù)據(jù)庫中鎖等待的方法

    快速查出Oracle數(shù)據(jù)庫中鎖等待的方法

    這篇文章主要介紹了快速查出Oracle數(shù)據(jù)庫中鎖等待的方法,在實際開發(fā)中很有應(yīng)用價值,需要的朋友可以參考下
    2014-08-08
  • Oracle存儲過程和自定義函數(shù)詳解

    Oracle存儲過程和自定義函數(shù)詳解

    本篇文章主要介紹了Oracle存儲過程和自定義函數(shù)詳解,有需要的可以了解一下。
    2016-11-11
  • Oracle 11.2.0.4打補丁的方法

    Oracle 11.2.0.4打補丁的方法

    這篇文章主要介紹了Oracle 11.2.0.4打補丁的方法,本文給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下
    2019-08-08
  • Oracle中的MD5加密詳解

    Oracle中的MD5加密詳解

    MD5是我們常用的一種加密方式,在各個方面都有用到這個加密方式,今天我們來探討下在Oracle中如何使用MD5加密
    2014-09-09
  • Oracle字符函數(shù)應(yīng)用檢測漢字的方法

    Oracle字符函數(shù)應(yīng)用檢測漢字的方法

    這篇文章主要介紹了Oracle字符函數(shù)應(yīng)用檢測漢字的方法,需要的朋友可以參考下
    2017-03-03
  • Oracle Instr函數(shù)實例講解

    Oracle Instr函數(shù)實例講解

    instr函數(shù)為字符查找函數(shù),其功能是查找一個字符串在另一個字符串中首次出現(xiàn)的位置,instr函數(shù)在Oracle/PLSQL中是返回要截取的字符串在源字符串中的位置,這篇文章主要介紹了Oracle Instr函數(shù)實例講解,需要的朋友可以參考下
    2022-11-11
  • oracle通過存儲過程上傳list保存功能

    oracle通過存儲過程上傳list保存功能

    這篇文章主要介紹了oracle通過存儲過程上傳list保存功能,本文通過實例代碼給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-05-05

最新評論