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

來源:互聯網
上載者:User

標籤:支援   欄位   例子   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做報表並帶小計合計常用到的函數

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.