SQL窗口函數(shù)OVER用法實例整理
OVER的定義
OVER用于為行定義一個窗口,它對一組值進行操作,不需要使用GROUP BY子句對數(shù)據(jù)進行分組,能夠在同一行中同時返回基礎行的列和聚合列。
語法
OVER ( [ PARTITION BY column ] [ ORDER BY culumn ] [ROWS|RANGE BETWEEN 邊界規(guī)則1 and 邊界規(guī)則2])
PARTITION BY 子句進行分組;
ORDER BY 子句進行排序;
ROWS|RANGE 框架是對窗口進行進一步的分區(qū),框架有兩種范圍限定方式:一種是使用ROWS子句,通過指定當前行之前或之后的固定數(shù)目的行來限制分區(qū)中的行數(shù);另一種是RANGE子句,按照排序列的當前值,根據(jù)相同值來確定分區(qū)中的行數(shù)。
窗口函數(shù)OVER()指定一組行,開窗函數(shù)計算從窗口函數(shù)輸出的結果集中各行的值。
RANGE表示按照值的范圍進行范圍的定義,而ROWS表示按照行的范圍進行范圍的定義;邊界規(guī)則的可取值見下表
用法
OVER開窗函數(shù)必須與聚合函數(shù)或排序函數(shù)一起使用,聚合函數(shù)一般指SUM(),MAX(),MIN,COUNT(),AVG()等常見函數(shù)。排序函數(shù)一般指RANK(),ROW_NUMBER(),DENSE_RANK(),NTILE()等。
示例
創(chuàng)建測試表
create table Employee ( ID INT PRIMARY KEY ,Name VARCHAR(20) ,GroupName VARCHAR(20) ,Salary INT ) INSERT into Employee VALUES(1, '小明', '開發(fā)部', 8000), (4, '小張', '開發(fā)部', 7600), (5, '小白', '開發(fā)部', 7000), (8, '小王', '財務部', 5000), (9, null, '財務部', NULL), (15, '小劉', '財務部', 6000), (16, '小高', '行政部', 4500), (18, '小王', '行政部', 4000), (23, '小李', '行政部', 4500), (29, '小吳', '行政部', 4700) ;
SUM后的開窗函數(shù)
select * ,SUM(Salary) OVER(PARTITION BY Groupname) 每個組的總工資 ,SUM(Salary) OVER(PARTITION BY groupname ORDER BY ID) 每個組的累計總工資 ,SUM(Salary) OVER(ORDER BY ID) 累計工資 ,SUM(Salary) OVER() 總工資 from Employee
結果如下:
其中開窗函數(shù)的每個含義不同,我們來具體解讀一下:
SUM(Salary) OVER (PARTITION BY Groupname)
只對PARTITION BY后面的列Groupname進行分組,分組后求解Salary的和。
SUM(Salary) OVER (PARTITION BY Groupname ORDER BY ID)
對PARTITION BY后面的列Groupname進行分組,然后按ORDER BY 后的ID進行排序,然后在組內對Salary進行累加處理。
SUM(Salary) OVER (ORDER BY ID)
只對ORDER BY 后的ID內容進行排序,對排完序后的Salary進行累加處理。
SUM(Salary) OVER ()
對Salary進行匯總處理
排序
ROW_NUMBER()
定義:ROW_NUMBER()函數(shù)作用就是將SELECT查詢到的數(shù)據(jù)進行排序,每一條數(shù)據(jù)加一個序號
select * ,ROW_NUMBER() OVER (PARTITION BY ClassName ORDER BY SCORE DESC) 班內排序 ,ROW_NUMBER() OVER (ORDER BY SCORE DESC) AS 總排序 from Scores ;
RANK()
select ROW_NUMBER() OVER (ORDER BY SCORE DESC) AS [RANK] ,* from Scores ; select RANK() OVER (ORDER BY SCORE DESC) AS [RANK] ,* from Scores ;
NTILE()
定義:NTILE(N)函數(shù)是將數(shù)據(jù)分成N塊,然后再添加1~N的序號。
select * ,NTILE(1) OVER (ORDER BY SCORE DESC) AS 分區(qū)后排序 from Scores ; select * ,NTILE(2) OVER (ORDER BY SCORE DESC) AS 分區(qū)后排序 from Scores ; select * ,NTILE(3) OVER (ORDER BY SCORE DESC) AS 分區(qū)后排序 from Scores ;
ROWS|RANGE
select * ,SUM(Salary) OVER(PARTITION BY groupname ORDER BY ID ROWS between CURRENT ROW and 5 FOLLOWING) 從當前行開始后5行的和 from Employee
參考
https://www.modb.pro/db/42912
總結
到此這篇關于SQL窗口函數(shù)OVER用法的文章就介紹到這了,更多相關SQL窗口函數(shù)OVER內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
MySQL關聯(lián)查詢優(yōu)化實現(xiàn)方法詳解
在數(shù)據(jù)庫的設計中, 我們通常都是會有很多張表 , 通過表與表之間的關系建立我們想要的數(shù)據(jù)關系, 所以在多張表的前提下, 多表的關聯(lián)查詢就尤為重要,這篇文章主要介紹了MySQL關聯(lián)查詢優(yōu)化2022-11-11