偷偷摘套内射激情视频,久久精品99国产国产精,中文字幕无线乱码人妻,中文在线中文a,性爽19p

Oracle over() 函數(shù)的實(shí)際用法

數(shù)據(jù)庫(kù) Oracle
我們今天主要介紹的是Oracle over() 函數(shù)的實(shí)際用法,以及在實(shí)際操作中的相關(guān)代碼的描述,以下就是文章的詳細(xì)內(nèi)容介紹,望大家借鑒。

以下的文章主要介紹的是Oracle over() 函數(shù)的實(shí)際用法,在一個(gè)網(wǎng)站上我無(wú)意中看見(jiàn)了這個(gè)函數(shù),才對(duì)Oracle分析函數(shù)的相關(guān)內(nèi)容有所了解,而且Oracle over() 函數(shù)的實(shí)際用法又尤為的特別,所以將自己的研究結(jié)果記錄一下。

個(gè)人理解:over() 函數(shù)是對(duì)分析函數(shù)的一種條件解釋,直接點(diǎn)就是 給分析函數(shù)加條件吧。

在網(wǎng)上看見(jiàn)比較常用的就是 與 sum()、rank() 函數(shù)使用。接下來(lái)就用分析下兩種函數(shù)結(jié)合over的用法。

以下測(cè)試使用的orace默認(rèn)的 scott用戶下的emp表數(shù)據(jù)。

1.sum()結(jié)合Oracle over()

Sql代碼

select a.empno as 員工編號(hào)

,a.ename as 員工姓名

,a.deptno as 部門(mén)編號(hào)

,a.sal as 薪酬

,sum(sal) over (partition by deptno) 按部門(mén)求薪酬總和

from scott.emp a;

此段sql 執(zhí)行的結(jié)果為:

部門(mén)編號(hào) 員工姓名 員工編碼 薪酬 按部門(mén)求薪酬總和

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

可以從結(jié)果上看到sum()函數(shù)對(duì)部門(mén)區(qū)分進(jìn)行了求和統(tǒng)計(jì)。其中“partition by”官方點(diǎn)的說(shuō)法叫做"分區(qū)",其實(shí)就是統(tǒng)計(jì)的范圍條件。

下面在給把上面的sql語(yǔ)句改造下 給 Oracle over() 函數(shù)加上 “order by sal” 會(huì)看到一個(gè)更過(guò)癮的效果:

Sql代碼

select a.empno as 員工編號(hào)

,a.ename as 員工姓名

,a.deptno as 部門(mén)編號(hào)

,a.sal as 薪酬

,sum(sal) over (partition by deptno) 按部門(mén)求薪酬總和

,sum(sal) over (partition by deptno order by sal) 按部門(mén)累計(jì)薪酬

from scott.emp a;

結(jié)果為:

部門(mén)編號(hào) 員工姓名 員工編碼 薪酬 按部門(mén)求薪酬總和 按部門(mén)累計(jì)薪酬

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

從結(jié)果中可以看的 加了 “order by”后對(duì) 統(tǒng)計(jì)進(jìn)行一個(gè)累加,這里個(gè)人理解為對(duì)統(tǒng)計(jì)范圍規(guī)定了個(gè)統(tǒng)計(jì)順利,一步一步的統(tǒng)計(jì)。

注:此sql語(yǔ)句結(jié)尾處不要加“order by”,應(yīng)為使用的分析函數(shù)的(partition by deptno order by sal)

里已經(jīng)有排序的語(yǔ)句了,如果再在句尾添加排序子句,一致倒罷了,不一致,結(jié)果就令人費(fèi)解了。

2.rank()結(jié)合Oracle over()

rank函數(shù)是分級(jí)函數(shù),這個(gè)函數(shù)必須與 over 函數(shù)使用,否則會(huì)報(bào)一個(gè)"缺少窗口函數(shù)的錯(cuò)"。我測(cè)試sql如下:

Sql代碼

select a.empno as 員工編號(hào),

a.sal as 薪資,

a.job as 崗位,

rank() OVER(partition by a.job ORDER BY a.sal desc) as 崗位薪資等級(jí)

from scott.emp a;

查詢結(jié)果為:

員工編號(hào) 薪資 崗位 等級(jí)

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

【編輯推薦】

  1. Oracle數(shù)據(jù)庫(kù)與Access互導(dǎo)實(shí)例
  2. Oracle 11g R2數(shù)據(jù)衛(wèi)士的增強(qiáng)特性表現(xiàn)
  3. Oracle Redo的并行機(jī)制運(yùn)行中要用到的代碼
  4. Oracle提高SQL的執(zhí)行效率的3種好用方法
  5. Oracle臨時(shí)表用法的經(jīng)驗(yàn)心得
責(zé)任編輯:佚名 來(lái)源: 互聯(lián)網(wǎng)
相關(guān)推薦

2010-10-25 13:33:10

Oracle over

2010-04-28 16:30:52

Oracle case

2010-04-28 14:56:02

Oracle sqlp

2010-04-28 14:46:38

Oracle Copy

2010-05-07 18:52:59

Oracle rown

2011-04-08 15:50:54

Oracleover函數(shù)

2010-04-27 14:44:31

Oracle存儲(chǔ)過(guò)程

2010-05-05 15:38:31

Oracle安全策略

2010-04-29 13:31:16

Oracle Orad

2010-05-31 14:16:01

MySQL數(shù)學(xué)函數(shù)

2010-04-06 08:58:27

Oracle job

2010-10-25 14:28:53

oracle trun

2010-10-25 16:52:48

oracle管道函數(shù)

2010-04-29 10:41:55

2010-04-29 13:53:42

Oracle臨時(shí)表

2010-04-30 17:58:55

Oracle trun

2010-04-27 12:51:49

Oracle 函數(shù)de

2010-05-10 18:22:28

Oracle deco

2010-05-06 15:44:08

Oracle Nvl函

2010-04-30 10:47:26

Oracle Nvl函
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)