linux decode函数,Oracle 中 decode 函数用法
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并在前面補0select 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 decode(性別,男,1,0),decode(性別,女,1,0) from 表
總結
以上是生活随笔為你收集整理的linux decode函数,Oracle 中 decode 函数用法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 重装机兵4金手指怎么用
- 下一篇: linux 内核 4.10.0,Bodh