自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

Oracle數(shù)據(jù)庫中Rank等函數(shù)的比較與選擇

數(shù)據(jù)庫 Oracle
本文我們通過一個實例來對Oracle數(shù)據(jù)庫中的Rank,Dense_Rank,Row_Number進行比較,通過比較我們可以學(xué)習(xí)結(jié)合具體得情況來使用最合適的函數(shù),接下來就讓我們來一起學(xué)習(xí)吧。

Oracle數(shù)據(jù)庫中Rank,Dense_Rank,Row_Number函數(shù)有什么樣的區(qū)別呢?在實際的應(yīng)用中我們又該如何去選擇呢?本文結(jié)合實例說明了這些。

首先我們先創(chuàng)建一個員工信息表,在查詢分析器中執(zhí)行以下的代碼:

  1. Create Table EmployeeInfo (CODE Number(3) Not Null,EmployeeName varchar2(15),DepartmentID Number(3),Salary NUMBER(7,2),  
  2.  
  3. Constraint PK_EmployeeInfo Primary Key (CODE)); 

創(chuàng)建完成后,在企業(yè)管理其中打開表,錄入一些信息,為了讓大家清楚錄入的內(nèi)容,錄入完畢后我執(zhí)行了查詢語句Select * From EMPLOYEEINFO;將員工信息表的內(nèi)容入下圖所示:

Oracle數(shù)據(jù)庫中Rank等函數(shù)的比較與選擇

現(xiàn)執(zhí)行SQL語句:

  1. Select EMPLOYEENAME,SALARY,  
  2.  
  3. RANK() OVER (Order By SALARY Desc)  "RANK",  
  4.  
  5. DENSE_RANK() OVER (Order By SALARY Desc ) "DENSE_RANK",  
  6.  
  7. ROW_NUMBER() OVER(Order By SALARY Desc) "ROW_NUMBER"  
  8.  
  9.  From EMPLOYEEINFO 

結(jié)果如下:

Oracle數(shù)據(jù)庫中Rank等函數(shù)的比較與選擇

說明:Rank,Dense_rank,Row_number函數(shù)為每條記錄產(chǎn)生一個從1開始至N的自然數(shù),N的值可能小于等于記錄的總數(shù)。這3個函數(shù)的唯一區(qū)別在于當(dāng)碰到相同數(shù)據(jù)時的排名策略。

①ROW_NUMBER:

Row_number函數(shù)返回一個唯一的值,當(dāng)碰到相同數(shù)據(jù)時,排名按照記錄集中記錄的順序依次遞增。

②DENSE_RANK:

Dense_rank函數(shù)返回一個唯一的值,除非當(dāng)碰到相同數(shù)據(jù)時,此時所有相同數(shù)據(jù)的排名都是一樣的。

③RANK:

Rank函數(shù)返回一個唯一的值,除非遇到相同的數(shù)據(jù)時,此時所有相同數(shù)據(jù)的排名是一樣的,同時會在***一條相同記錄和下一條不同記錄的排名之間空出排名。

同時也可以分組排序,也就是在Over從句內(nèi)加入Partition by groupField:

  1. Select DEPARTMENTID,EMPLOYEENAME,SALARY,  
  2.  
  3. RANK() OVER ( Partition By DEPARTMENTID Order By SALARY Desc)  "RANK",  
  4.  
  5. DENSE_RANK() OVER ( Partition By DEPARTMENTID Order By SALARY Desc ) "DENSE_RANK",  
  6.  
  7. ROW_NUMBER() OVER( Partition By DEPARTMENTID Order By SALARY Desc) "ROW_NUMBER"  
  8.  
  9. From EMPLOYEEINFO 

結(jié)果如下:

Oracle數(shù)據(jù)庫中Rank等函數(shù)的比較與選擇

現(xiàn)在如果插入一條工資為空的記錄,那么執(zhí)行上述語句,結(jié)果如下:

Oracle數(shù)據(jù)庫中Rank等函數(shù)的比較與選擇

會發(fā)現(xiàn)空值的竟然排在了***位,這顯然不是想要的結(jié)果。解決的辦法是在Over從句Order By后加上 NULLS Last即:

  1. Select EMPLOYEENAME,SALARY,  
  2.  
  3. RANK() OVER (Order By SALARY Desc  Nulls Last)  "RANK",  
  4.  
  5. DENSE_RANK() OVER (Order By SALARY Desc Nulls Last) "DENSE_RANK",  
  6.  
  7. ROW_NUMBER() OVER(Order By SALARY Desc Nulls Last ) "ROW_NUMBER"  
  8.  
  9. From EMPLOYEEINFO 

結(jié)果如下:

Oracle數(shù)據(jù)庫中Rank等函數(shù)的比較與選擇

本文就介紹到這里,如果您想了解更多關(guān)于Oracle的內(nèi)容,可以到我們網(wǎng)站的Oracle頻道:http://database.51cto.com/oracle/,謝謝大家的支持!

【編輯推薦】

  1. C#利用ODP.net連接Oracle數(shù)據(jù)庫
  2. 利用Sql Server將Excel中的數(shù)據(jù)導(dǎo)入Oracle
  3. 在存儲過程中連接遠程Oracle數(shù)據(jù)庫并進行操作
  4. 環(huán)境變量導(dǎo)致ASP.Net無法連接Oracle的一個案例
  5. ORACLE數(shù)據(jù)庫PL/SQL編程之把過程與函數(shù)說透
責(zé)任編輯:趙鵬 來源: 網(wǎng)易博客
相關(guān)推薦

2011-03-18 11:24:07

Oracle 數(shù)據(jù)庫時間問題

2010-03-31 19:34:03

Oracle數(shù)據(jù)庫

2010-04-29 09:35:31

Oracle數(shù)據(jù)庫

2010-03-30 17:40:59

Oracle數(shù)據(jù)庫

2010-11-15 16:13:24

Oracle數(shù)據(jù)庫性能

2010-05-14 17:34:36

MySQL數(shù)據(jù)庫列值

2011-07-22 09:33:15

OracleMySQLPostgreSQL

2021-01-10 15:29:53

開源數(shù)據(jù)庫數(shù)據(jù)庫

2010-08-25 15:13:22

DB2Oracle數(shù)據(jù)庫

2011-08-23 15:16:54

OracleMySQL

2021-10-26 08:00:00

數(shù)據(jù)庫架構(gòu)技術(shù)

2021-09-02 10:54:39

Pandas函數(shù)數(shù)據(jù)

2009-07-02 00:00:00

OOPOracle

2009-09-04 09:54:59

數(shù)據(jù)庫名

2025-04-08 06:00:00

2011-04-12 10:21:24

Oracle數(shù)據(jù)庫索引樹

2010-04-28 16:37:31

Oracle數(shù)據(jù)字典

2011-03-11 16:42:51

Oracle數(shù)據(jù)庫視圖

2010-04-02 17:11:45

Oracle數(shù)據(jù)庫

2010-05-21 10:22:37

MySQL數(shù)據(jù)庫
點贊
收藏

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