SQLServer三種開窗函數(shù)詳細(xì)用法
一,開窗函數(shù)的語法
開窗函數(shù)的語法為:over(partition by 列名1 order by 列名2 ),括號中的兩個關(guān)鍵詞partition by 和order by 可以只出現(xiàn)一個。over() 前面是一個函數(shù),如果是聚合函數(shù),那么order by 不能一起使用。
二,從聚合開窗函數(shù)sum(score) over(partition by name )講起
實不相瞞我看一眼就會了(假的,其實這種又臭又長的字實在懶得看)
sum(score) over(partition by name )
sum()是聚合函數(shù),其實我聚合函數(shù)還沒學(xué)明白,當(dāng) sum()函數(shù) 后面跟上 over()以后,由sum聚合函數(shù)就成為了開窗函數(shù)。
over() 括號里面就是定義窗口的內(nèi)容了,partition 是分區(qū),分組的意思。partition by 就是根據(jù)某個字段分組。
所以sum(score) over(partition by name ) ,就是先根據(jù) name 分組(如圖),當(dāng)前面加了sum(score)后就把根據(jù)name分組后的,每個(組)窗口里面的字段 score進(jìn)行求和操作。
select *,sum(score) over(partition by name) sum窗口函數(shù)舉例 from kchs -- 為了簡單就只有兩個字段,name和score
聚合函數(shù)同樣需要對數(shù)據(jù)進(jìn)行排序,但不會顯示排名結(jié)果。會將當(dāng)前名次的數(shù)據(jù) 與 排在這之前的所有數(shù)據(jù) 依次做相應(yīng)的計算。
執(zhí)行語句:
select *, sum(score) over (order by id) as 累加求和 from kchs
拓展一下:
一,很多聚合函數(shù)都可以用作窗口函數(shù)的運算,如SUM、AVG、MAX、MIN、COUNT。
二,和gropu by 不同的是窗口函數(shù)會生成多行,而不是想group by 一樣只有一行
三,開窗函數(shù)之first_value,last_value,lead,lag
first_value:是在窗口里面取到第一個值
first_value(score) over( partition by name)as first_score , 根據(jù)name分區(qū)(組),取score列的第一個值
last_value:是在窗口里面取到最后一個值
last_value(score) over(partition by name) as last_score --根據(jù)name分區(qū)(組),取score列的最后一個值
lead 是取當(dāng)前行的上 N 條數(shù)據(jù),并且可以設(shè)置默認(rèn)值
lead(score,1,0) over(partition by name ) as lead_score --根據(jù)name分區(qū)(組),score列當(dāng)前行的上面N行,,如果沒有就為默認(rèn)值0
lag 是取當(dāng)前行的下 N 條數(shù)據(jù),并且可以設(shè)置默認(rèn)值
lag(score,1,0) over(partition by name ) as lag_score --根據(jù)name分區(qū)(組),score列當(dāng)前行的下面N行,如果沒有就為默認(rèn)值0
四,排名開窗函數(shù)ROW_NUMBER、DENSE_RANK、RANK
row_number ()是為每組的行設(shè)置一個連續(xù)的遞增的數(shù)字(123456)
ROW_NUMBER() over( partition by name order by score asc)as ROW_NUMBER_score
rank()是排名,也為每一組的行生成一個序號,如果有相同的值會生成相同的序號,并且接下來的序號是不連序的。例如:有三個人并列第一名,第四名序號為四(111456)
rank() over(partition by name order by score asc) as RANK_score
DENSE_RANK()和RANK()類似,不同的是如果有相同的序號,那么接下來的序號不會間斷。例如:有三個人并列第一,第四名序號為2(111234)
DENSE_RANK() over(partition by name order by score asc) as DENSE_RANK_score
注意:
一,排名開窗函數(shù)可以單獨使用ORDER BY 語句,也可以和PARTITION BY同時使用。
二,ORDER BY 指定排名開窗函數(shù)的順序,在排名開窗函數(shù)中必須使用ORDER BY語句。
三,PARTITION BY用于將結(jié)果集進(jìn)行分組,開窗函數(shù)應(yīng)用于每一組。
到此這篇關(guān)于SQLServer三種開窗函數(shù)詳細(xì)用法的文章就介紹到這了,更多相關(guān)SQLServer 開窗函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
sqlserver中比較一個字符串中是否含含另一個字符串中的一個字符
sql中比較一個字符串中是否含有另一個字符串中的一個字符的實現(xiàn)代碼,需要的朋友可以參考下。2010-09-09sql server使用公用表表達(dá)式CTE通過遞歸方式編寫通用函數(shù)自動生成連續(xù)數(shù)字和日期
CTE是在內(nèi)存中準(zhǔn)備好數(shù)據(jù),而不是每次一條往返服務(wù)器和客戶端一次。如果需要再插入到臨時表的話就是全部數(shù)據(jù)一次性插入。 這篇文章主要介紹了sql server使用公用表表達(dá)式CTE通過遞歸方式編寫通用函數(shù)自動生成連續(xù)數(shù)字和日期 ,需要的朋友可以參考下2019-07-07SQLServer中bigint轉(zhuǎn)int帶符號時報錯問題解決方法
用一個函數(shù)來解決SQLServer中bigint轉(zhuǎn)int帶符號時報錯問題,經(jīng)測試可用,有類似問題的朋友可以參考下2014-09-09完美解決MSSQL"以前的某個程序安裝已在安裝計算機(jī)上創(chuàng)建掛起的文件操作"
以前裝過sql server,后來刪掉?,F(xiàn)在重裝,卻出現(xiàn)“以前的某個程序安裝已在安裝計算機(jī)上創(chuàng)建掛起的文件操作。運行安裝程序之前必須重新啟動計算機(jī)”錯誤。無法進(jìn)行下去。 現(xiàn)在又遇到了,終于完全搞定.2008-11-11SQL SERVER2012中新增函數(shù)之字符串函數(shù)CONCAT詳解
SQL Server 2012有一個新函數(shù),就是CONCAT函數(shù),連接字符串非它莫屬。比如在它出現(xiàn)之前,連接字符串是使用"+"來連接,如遇上NULL,還得設(shè)置參數(shù)與配置,不然連接出來的結(jié)果將會是一個NULL。本文就介紹了關(guān)于SQL SERVER 2012中CONCAT函數(shù)的相關(guān)資料,需要的朋友可以參考。2017-03-03SQL Server中參數(shù)化SQL寫法遇到parameter sniff ,導(dǎo)致不合理執(zhí)行計劃重用的快速解決方法
這篇文章主要介紹了SQL Server中參數(shù)化SQL寫法遇到parameter sniff ,導(dǎo)致不合理執(zhí)行計劃重用的快速解決方法的相關(guān)資料,需要的朋友可以參考下2016-07-07