成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Oracle over() 函數的實際用法

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

以下的文章主要介紹的是Oracle over() 函數的實際用法,在一個網站上我無意中看見了這個函數,才對Oracle分析函數的相關內容有所了解,而且Oracle over() 函數的實際用法又尤為的特別,所以將自己的研究結果記錄一下。

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

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

以下測試使用的orace默認的 scott用戶下的emp表數據。

1.sum()結合Oracle 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語句改造下 給 Oracle 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()結合Oracle 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

【編輯推薦】

  1. Oracle數據庫與Access互導實例
  2. Oracle 11g R2數據衛士的增強特性表現
  3. Oracle Redo的并行機制運行中要用到的代碼
  4. Oracle提高SQL的執行效率的3種好用方法
  5. Oracle臨時表用法的經驗心得
責任編輯:佚名 來源: 互聯網
相關推薦

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函數

2010-04-27 14:44:31

Oracle存儲過程

2010-05-05 15:38:31

Oracle安全策略

2010-04-29 13:31:16

Oracle Orad

2010-05-31 14:16:01

MySQL數學函數

2010-04-06 08:58:27

Oracle job

2010-10-25 14:28:53

oracle trun

2010-10-25 16:52:48

oracle管道函數

2010-04-29 10:41:55

2010-04-29 13:53:42

Oracle臨時表

2010-04-30 17:58:55

Oracle trun

2010-04-27 12:51:49

Oracle 函數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函
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 久久亚洲国产精品 | 日韩在线三级 | 精品伊人久久 | 欧美亚洲另类丝袜综合网动图 | 婷婷丁香综合网 | 成人性生交大片免费看r链接 | 五月网婷婷 | 91在线一区 | 男女精品网站 | 特级黄一级播放 | 在线色网| 91麻豆精品国产91久久久更新资源速度超快 | 久久精品久久综合 | 7777在线视频 | 久久久久国产一区二区三区四区 | 九九视频网 | 久久久久国产精品一区二区 | 中文字幕日韩专区 | 日韩精品无码一区二区三区 | 日韩一区二区三区视频 | 你懂的在线视频播放 | 亚洲三区视频 | 亚洲91av| 久久精片 | 一级黄a视频 | 福利在线观看 | 欧洲亚洲视频 | 综合久久一区 | 成人免费视频网站在线观看 | 久久久久国产精品一区二区 | 91国产在线视频在线 | 欧洲精品一区 | 男人的天堂中文字幕 | 国产一区二区三区四区 | 亚洲美女一区二区三区 | 欧美日韩在线免费观看 | 好姑娘影视在线观看高清 | 精品伊人久久 | 日韩高清三区 | 中文字字幕一区二区三区四区五区 | 国产成人99久久亚洲综合精品 |