oracle中over 函式用法

2021-08-30 07:42:20 字數 3710 閱讀 8866

在泡罈子的時候中無意中發現了這個函式,才知道oracle分析函式是如此的強大,其中over() 函式的用法又尤為的特別,所以將自己的研究結果記錄一下。

個人理解:over() 函式 是對 分析函式的一種條件解釋,直接點就是 給分析函式加條件吧。

在網上看見比較常用的就是 與 sum()、rank() 函式使用。接下來就用分析下兩種函式結合over的用法。

以下測試使用的orace預設的 scott使用者下的emp表資料。

1.sum()結合over()

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

101300

8750

7782

clark

102450

8750

7839

king

105000

8750

7369

smith

20800

10875

7876

adams

201100

10875

7566

jones

202975

10875

7788

scott

203000

10875

7902

ford

203000

10875

7900

james

30950

9400

7654

martin

301250

9400

7521

ward

301250

9400

7844

turner

301500

9400

7499

allen

301600

9400

7698

blake

302850

9400

可以從結果上看到sum()函式對部門區分進行了求和統計。其中「partition by」官方點的說法叫做"分割槽",其實就是統計的範圍條件。

下面在給把上面的sql語句改造下 給 over() 函式加上 「order by sal」 會看到乙個更過癮的效果:

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

101300

8750

1300

7782

clark

102450

8750

3750

7839

king

105000

8750

8750

7369

smith

20800

10875

8007876

adams

201100

10875

1900

7566

jones

202975

10875

4875

7788

scott

203000

10875

10875

7902

ford

203000

10875

10875

7900

james

30950

9400

9507654

martin

301250

9400

3450

7521

ward

301250

9400

3450

7844

turner

301500

9400

4950

7499

allen

301600

9400

6550

7698

blake

302850

9400

9400

從結果中可以看的 加了 「order by」後對 統計進行乙個累加,這裡個人理解為對統計範圍規定了個統計順利,一步一步的統計。

注:此sql語句結尾處不要加「order by」,應為使用的分析函式的(partition by deptno order by sal)

裡已經有排序的語句了,如果再在句尾新增排序子句,一致倒罷了,不一致,結果就令人費解了。

2.rank()結合over()

rank函式是分級函式,這個函式必須與 over 函式使用,否則會報乙個"缺少視窗函式的錯"。我測試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

17788

3000

analyst

17934

1300

clerk

17876

1100

clerk

27900

950clerk

37369

800clerk

47566

2975

manager

17698

2850

manager

27782

2450

manager

37839

5000

president

17499

1600

salesman

17844

1500

salesman

27654

1250

salesman

37521

1250

salesman

3

oracle中over 函式用法

oracle分析函式是如此的強大,其中over 函式的用法又尤為的特別,所以將自己的研究結果記錄一下。個人理解 over 函式 是對 分析函式的一種條件解釋,直接點就是 給分析函式加條件吧。在網上看見比較常用的就是 與 sum rank 函式使用。接下來就用分析下兩種函式結合over的用法。以下測試...

oracle 分析函式之 over 用法

僅供個人學習提高使用。oracle 語法之 over partition by select from test 資料 a b c 1 1 1 1 2 2 1 3 3 2 2 5 3 4 6 將b列值相同的對應的c 列值加總 select a,b,c,sum c over partition by ...

Oracle中Over函式使用

個人理解 over 函式 是對 分析函式的一種條件解釋,直接點就是 給分析函式加條件吧。在網上看見比較常用的就是 與 sum rank 函式使用。接下來就用分析下兩種函式結合over的用法。以下測試使用的orace預設的 scott使用者下的emp表資料。1.sum 結合over sql selec...