SQL 窗口函示例數(shù)詳解
1.窗口函數(shù)之排序函數(shù)
RANK, DENSE_RANK, ROW_NUMBER
1.RANK函數(shù)
計算排序時,如果存在相同位次的記錄,則會跳過之后的位次
有 3 條記錄排在第 1 位時: 1 位、1 位、1 位、4 位…
2.DENSE_RANK函數(shù)
同樣是計算排序,即使存在相同位次的記錄,也不會跳過之后的位次
有 3 條記錄排在第 1 位時: 1 位、1 位、1 位、2 位
3.ROW_NUMBER函數(shù)
賦予唯一的連續(xù)位次。
例)有 3 條記錄排在第 1 位時: 1 位、2 位、3 位、4 位
語法<窗口函數(shù)> OVER ([PARTITION BY <列清單>] ORDER BY <排序用列清單>)
根據(jù)分數(shù)對學生從高到低排名,不對科目進行分組,成績相同則排名相同并且位次連續(xù)
SELECT student_name, score, DENSE_RANK() OVER(ORDER BY score DESC) AS 'rank' FROM grade;
根據(jù)分數(shù)對同科目的學生從高到低排名,成績相同,排名不相同
SELECT student_name, score, ROW_NUMBER() OVER(PARTITION BY course_name ORDER BY score DESC) AS 'rank' FROM grade;
窗口函數(shù)使用場景
1.直接排序:按照某列對數(shù)據(jù)進行排序
2.Top-k:查詢排名TOP-k的數(shù)據(jù)
3.最值問題:查詢最大、最多的數(shù)據(jù)
4.輔助列:比如計算連續(xù)登陸問題、用SQL計算平均數(shù)、眾數(shù)、中位數(shù)(可以參考我之前的視頻)
到此這篇關于SQL 窗口函數(shù)的文章就介紹到這了,更多相關SQL 窗口函數(shù)內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SQL Server誤區(qū)30日談 第20天 破壞日志備份鏈之后,需要一個完整備份來重新開始日志鏈
事務日志備份會備份自上次事務日志備份以來所有的事務日志(如果從來沒有過日志備份的話,那就從上一次完整備份開始)。有好幾種類型的操作會中斷事務日志的連續(xù)性,也就是說除非重新開始新的日志鏈,SQL Server無法再進行日志備份2013-01-01SQLServer2008R2版安裝和測試的實現(xiàn)
本文主要介紹了在Windows10上安裝和配置SQL?Server?2008R2,內容涵蓋了安裝過程中的注意事項,如安裝.NET?Framework?3.5、處理遠程過程調用失敗等常見問題,感興趣的可以了解一下2024-12-12SQL Server 2014 數(shù)據(jù)庫中文版安裝圖文教程
這篇文章主要介紹了SQL Server 2014 數(shù)據(jù)庫中文版安裝圖文教程,需要的朋友可以參考下2021-05-05SQL Server 2019 密碼修改的實現(xiàn)步驟
為了保護數(shù)據(jù)庫中的數(shù)據(jù),我們經(jīng)常需要定期更改數(shù)據(jù)庫用戶的密碼,本文主要介紹了SQL Server 2019 密碼修改的實現(xiàn)步驟,具有一定的參考價值,感興趣的可以了解一下2023-09-09刪除數(shù)據(jù)庫中重復數(shù)據(jù)的幾個方法
刪除數(shù)據(jù)庫中重復數(shù)據(jù)的幾個方法...2006-12-12