oracle中over()分析函数的用法
摘自:?http://www.poluoluo.com/jzxy/201004/81921.html
?
百度文庫也記載了oracle中over()分析函數的用法
在泡壇子的時候中無意中發現了這個函數,才知道oracle分析函數是如此的強大,其中over() 函數的用法又尤為的特別,所以將自己的研究結果記錄一下。
個人理解:over() 函數 是對 分析函數的一種條件解釋,直接點就是 給分析函數加條件吧。
在網上看見比較常用的就是 與 sum()、rank() 函數使用。接下來就用分析下兩種函數結合over的用法。
以下測試使用的orace默認的 scott用戶下的emp表數據。
1.sum()結合over()
Sql代碼
select a.empno as 員工編號
,a.ename as 員工姓名
,a.deptno as 部門編號
,a.sal as 薪酬
,sum(sal) over (partition by deptno) 按部門求薪酬總和
from scott.emp a;
此段sql 執行的結果為:
員工編碼 員工姓名? 部門編號? 薪酬? 按部門求薪酬總和
7934? ? ? ? MILLER? ? ? 10? ? ? ? ?1300? ? ? ? ? 8750
7782? ? ? ? CLARK? ? ? ? 10? ? ? ? 2450? ? ? ? ?8750
7839? ? ? ? KING? ? ? ? ? ?10? ? ? ? 5000? ? ? ? ?8750
7369? ? ? ? SMITH? ? ? ? ?20? ? ? ? 800? ? ? ? ? ?10875
7876? ? ? ? ADAMS? ? ? ?20? ? ? ? 1100? ? ? ? ?10875
7566? ? ? ? JONES? ? ? ? ?20? ? ? ?2975? ? ? ? ?10875
7788? ? ? ? SCOTT? ? ? ? ?20? ? ? ?3000? ? ? ? ?10875
7902? ? ? ? FORD? ? ? ? ? ?20? ? ? ?3000? ? ? ? ? 10875
7900? ? ? ?JAMES? ? ? ? ? 30? ? ? ?950? ? ? ? ? ? ?9400
7654? ? ? ?MARTIN? ? ? ? 30? ? ? ?1250? ? ? ? ? ?9400
7521? ? ? ?WARD? ? ? ? ? ? 30? ? ? 1250? ? ? ? ? ?9400
7844? ? ? ?TURNER? ? ? ? 30? ? ? 1500? ? ? ? ? ?9400
7499? ? ? ?ALLEN? ? ? ? ? ? 30? ? ? 1600? ? ? ? ? 9400
7698? ? ?BLAKE 30 2850 9400
可以從結果上看到sum()函數對部門區分進行了求和統計。其中“partition by”官方點的說法叫做"分區",其實就是統計的范圍條件。
下面在給把上面的sql語句改造下 給 over() 函數加上 “order by sal” 會看到一個更過癮的效果:
Sql代碼
select a.empno as 員工編號
,a.ename as 員工姓名
,a.deptno as 部門編號
,a.sal as 薪酬
,sum(sal) over (partition by deptno) 按部門求薪酬總和
,sum(sal) over (partition by deptno order by sal) 按部門累計薪酬
from scott.emp a;
結果為:
員工編碼? ?員工姓名? 部門編號? 薪酬? 按部門求薪酬總和? 按部門累計薪酬
7934? ? ? ? ? ?MILLER? ? ? ? 10? ? ? 1300? ? ? ? ? ? ? ?8750? ? ? ? ? ? ? ? ? 1300
7782? ? ? ? ? CLARK? ? ? ? ? 10? ? ? ?2450? ? ? ? ? ? ? 8750? ? ? ? ? ? ? ? ? ?3750
7839? ? ? ? ? KING? ? ? ? ? ? ?10? ? ? ?5000? ? ? ? ? ? ? ?8750? ? ? ? ? ? ? ? ? 8750
7369? ? ? ? ? SMITH? ? ? ? ? 20? ? ? ? 800? ? ? ? ? ? ? ? 10875? ? ? ? ? ? ? ? ?800
7876? ? ? ? ? ?ADAMS? ? ? ? 20? ? ? ?1100? ? ? ? ? ? ? ?10875? ? ? ? ? ? ? ? ?1900
7566? ? ? ? ? JONES? ? ? ? ?20? ? ? ? 2975? ? ? ? ? ? ? ?10875? ? ? ? ? ? ? ? ?4875
7788? ? ? ? ? SCOTT? ? ? ? ?20? ? ? ? 3000? ? ? ? ? ? ? ?10875? ? ? ? ? ? ? ?10875
7902? ? ? ? ? FORD? ? ? ? ? ?20? ? ? ? 3000? ? ? ? ? ? ? ?10875? ? ? ? ? ? ? ?10875
7900? ? ? ? ?JAMES? ? ? ? ? 30? ? ? ? 950? ? ? ? ? ? ? ? ? 9400? ? ? ? ? ? ? ? ? ?950
7654? ? ? ? ? MARTIN? ? ? ?30? ? ? ? 1250? ? ? ? ? ? ? ? 9400? ? ? ? ? ? ? ? ? 3450
7521? ? ? ? ?WARD? ? ? ? ? ?30? ? ? ? 1250? ? ? ? ? ? ? ? 9400? ? ? ? ? ? ? ? ?3450
7844? ? ? ? ?TURNER? ? ? ?30? ? ? ?1500? ? ? ? ? ? ? ? ?9400? ? ? ? ? ? ? ? ?4950
7499? ? ? ? ? ALLEN? ? ? ? ?30? ? ? ? 1600? ? ? ? ? ? ? ? 9400? ? ? ? ? ? ? ? ?6550
7698? ? ? ? ?BLAKE? ? ? ? ? 30? ? ? ? 2850? ? ? ? ? ? ? ? 9400? ? ? ? ? ? ? ? ?9400
從結果中可以看的 加了 “order by”后對 統計進行一個累加,這里個人理解為對統計范圍規定了個統計順利,一步一步的統計。
注:此sql語句結尾處不要加“order by”,應為使用的分析函數的(partition by deptno order by sal)
里已經有排序的語句了,如果再在句尾添加排序子句,一致倒罷了,不一致,結果就令人費解了。
2.rank()結合over()
rank函數是分級函數,這個函數必須與 over 函數使用,否則會報一個"缺少窗口函數的錯"。我測試sql如下:
Sql代碼
select a.empno as 員工編號,
a.sal as 薪資,
a.job as 崗位,
rank() OVER(partition by a.job ORDER BY a.sal desc) as 崗位薪資等級
from scott.emp a;
查詢結果為:
員工編號 薪資 崗位 等級
7902? ? ? 3000 ANALYST 1
7788? ? ? 3000 ANALYST 1
7934? ? ? 1300 CLERK 1
7876? ? ? 1100 CLERK 2
7900? ? ? ?950 CLERK 3
7369 800 CLERK 4
7566 2975 MANAGER 1
7698 2850 MANAGER 2
7782 2450 MANAGER 3
7839 5000 PRESIDENT 1
7499 1600 SALESMAN 1
7844 1500 SALESMAN 2
7654 1250 SALESMAN 3
7521 1250 SALESMAN 3
創作挑戰賽新人創作獎勵來咯,堅持創作打卡瓜分現金大獎總結
以上是生活随笔為你收集整理的oracle中over()分析函数的用法的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 数据在市场运营中的应用
- 下一篇: S5PV210开发 -- 启动流程