oracle里面用sql做報表並帶小計合計常用到的函數


1-- DECODE函數是Oracle PL/SQL是功能強大的函數之一,假設我們想給職員加工資,其標准是:工資在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

注意:兩個參數得類型要匹配


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM