select unit_info.*,decode(ngrade,1,'一級',2,'二級',3,'**','其他') jb from unit_info;
先構造乙個例子,假設我們想給智星職員加工資,其標準是:工資在8000元以下的將加20%;工資在8000元以上的加15%,通常的做法是,先選出記錄 中的工資字段值?
select salary into var-salary from employee
然後對變數var-salary用if-then-else或choose case之類的流控制語句進行判斷。
如果用decode函式,那麼我們就可以把這些流控制語句省略,通過sql語句就可以直接完成。如下:
select decode(sign(salary - 8000),1,salary*1.15,-1,salary*1.2,salary from employee
是不是很簡潔?
decode的法:
decode(value,if1,then1,if2,then2,if3,then3,…,else)
表示如果value 等於if1時,decode函式的結果返回then1,…,如果不等於任何乙個if值,則返回else。初看一下,decode 只能做等於測試,但剛才也看到了,我們通過一些函式或計算替代value,是可以使decode函式具備大於、小於或等於功能。
trunc函式,decode函式
1 trunc number,num digits number是需要截尾取整的數字,也可以是日期 num digits用於指定整精度的數字 預設為0 trunc 函式擷取時不進行四捨五入 為123.456,123.546取整 select trunc 123.456 trunc 123.546 f...
Oracle函式 DECODE 函式
decode 函式,它將輸入數值與函式中的引數列表相比較,根據輸入值返回乙個對應值。函式的引數列表是由若干數值及其對應結果值組成的若干序偶形式。當然,如果未能與任何乙個實參序偶匹配成功,則函式也有預設的返回值。區別於sql的其它函式,decode函式還能識別和操作空值。語法 decode contr...
decode函式用法
decode 函式將該數值與一系列的序偶相比較,以決定最後的返回結果 序偶序偶,就是成對出現 我們將這個函式與 switch 比較,我們發現他們基本相似,唯一不同的是 switch 將要比較的值放在 case 後面都加上了 break中。select id,decode flag,y yes n n...