標籤:支援 欄位 例子 into rollup oracle ... null 控制語句
1-- DECODE函數是Oracle PL/SQL是功能強大的函數之一,目前還只有ORACLE公司的SQL提供了此函數,其他資料庫廠商的SQL實現還沒有此功能。DECODE有什麼用途 呢? 先構造一個例子,假設我們想給智星職員加工資,其標準是:工資在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函數具備大於、小於或等於功能。
2--比較大小函數SIGN
sign(x)或者Sign(x)叫做符號函數,其功能是取某個數的符號(正或負):當x>0,sign(x)=1;當x=0,sign(x)=0; 當x<0,sign(x)=-1;x可以是函數或計算運算式
3-- GROUPPING是一個彙總函式,它產生一個附加的列,當用 CUBE 或 ROLLUP 運算子添加行時,附加的列輸出值為1,當所添加的行不是由 CUBE 或 ROLLUP 產生時,附加列值為0。
文法: GROUPING ( column_name )
參數: column_name是 GROUP BY 子句中用於檢查 CUBE 或 ROLLUP 空值的列。
傳回型別: int
備忘: 分組用於區分由 CUBE 和 ROLLUP 返回的空值和標準的空值。作為CUBE 或 ROLLUP 操作結果返回的 NULL 是 NULL 的特殊應用。
4--ROLLUP 運算子產生摘要彙總, 需要匯總資訊時,此運算很有用。該運算子產生的結果集類似於 CUBE 運算子產生的結果集。但它們兩者有一些區別,CUBE 產生的結果集顯示了所選列中值的所有組合的彙總。而ROLLUP 產生的結果集顯示了所選列中值的某一階層的彙總。
文法: ROLLUP ( column_name1[,column_name2。。。] )
用法: 用在GROUP BY 子句中。對那些需要按其分組,並對其分組的彙總資料進行匯總的列,就請對這些列加上ROLLUP運算子。
5--NVL
文法
NVL(eExpression1, eExpression2)參數 eExpression1, eExpression2
如果 eExpression1 的計算結果為 null 值,則 NVL( ) 返回 eExpression2。如果 eExpression1 的計算結果不是 null 值,則返回 eExpression1。eExpression1 和 eExpression2 可以是任意一種資料類型。如果 eExpression1 與 eExpression2 的結果皆為 null 值,則 NVL( ) 返回 .NULL.。傳回值類型字元型、日期型、日期時間型、數值型、貨幣型、邏輯型或 null 值
說明
在不支援 null 值或 null 值無關緊要的情況下,可以使用 NVL( ) 來移去計算或操作中的 null 值。
select nvl(a.name,‘空得‘) as name from student a join school b on a.ID=b.ID
注意:兩個參數得類型要匹配
oracle裡面用sql做報表並帶小計合計常用到的函數