MySQL8 排名窗口函數(shù)實(shí)戰(zhàn)
在數(shù)據(jù)庫查詢與數(shù)據(jù)分析中,對數(shù)據(jù)分組并進(jìn)行排名是一項(xiàng)常見任務(wù)。SQL 窗口函數(shù)為此提供了高效的解決方案。本文旨在闡明三個(gè)核心排名函數(shù)——RANK()、DENSE_RANK() 與 ROW_NUMBER()——的功能、差異及適用場景。
示例數(shù)據(jù)模型
以下說明將基于一張students表示例,該表記錄了學(xué)生的班級與分?jǐn)?shù)。其中,'A'班存在分?jǐn)?shù)相同的學(xué)生,這有助于展示各函數(shù)的關(guān)鍵區(qū)別。
-- 表結(jié)構(gòu)與數(shù)據(jù)
create table students
(
id int auto_increment primary key,
name varchar(50) not null,
class varchar(10) null,
score int null
);
INSERT INTO students (name, class, score) VALUES
('甲', 'A', 85),
('乙', 'A', 90),
('丙', 'B', 95),
('丁', 'B', 80),
('張三', 'A', 90);
1.RANK(): 標(biāo)準(zhǔn)排名 (非連續(xù))
RANK() 函數(shù)提供標(biāo)準(zhǔn)的排名功能。當(dāng)存在數(shù)值相等的行時(shí),這些行將獲得相同的排名,但后續(xù)名次的序號將會跳躍。
查詢語句:
select name, class, score, rank() over (partition by class order by score desc) as class_rank from students;
結(jié)果:
| name | class | score | class_rank |
|---|---|---|---|
| 乙 | A | 90 | 1 |
| 張三 | A | 90 | 1 |
| 甲 | A | 85 | 3 |
| 丙 | B | 95 | 1 |
| 丁 | B | 80 | 2 |
分析: 在 'A' 班中,'乙' 和 '張三' 因分?jǐn)?shù)相同而并列第 1。隨后的 '甲' 的排名為第 3,序列跳過了第 2 名。
2.DENSE_RANK(): 緊湊排名 (連續(xù))
DENSE_RANK() 函數(shù)在處理并列排名時(shí),不會在名次序列中產(chǎn)生間隙,確保排名是連續(xù)的。
查詢語句:
select name, class, score, dense_rank() over (partition by class order by score desc) as class_rank from students;
結(jié)果:
| name | class | score | class_rank |
|---|---|---|---|
| 乙 | A | 90 | 1 |
| 張三 | A | 90 | 1 |
| 甲 | A | 85 | 2 |
| 丙 | B | 95 | 1 |
| 丁 | B | 80 | 2 |
分析: 在 'A' 班中,'乙' 和 '張三' 并列第 1 后,'甲' 的排名為第 2,名次序列保持了連續(xù)性。
3.ROW_NUMBER(): 行號分配 (唯一)
ROW_NUMBER() 函數(shù)不考慮數(shù)值的并列情況,它為分區(qū)內(nèi)的每一行分配一個(gè)從 1 開始的、唯一的、連續(xù)的整數(shù)。
查詢語句:
select name, class, score, row_number() over (partition by class order by score desc) as class_rank from students;
結(jié)果:
| name | class | score | class_rank |
|---|---|---|---|
| 乙 | A | 90 | 1 |
| 張三 | A | 90 | 2 |
| 甲 | A | 85 | 3 |
| 丙 | B | 95 | 1 |
| 丁 | B | 80 | 2 |
分析: 即使 '乙' 和 '張三' 的分?jǐn)?shù)相同,
ROW_NUMBER()依然為它們分配了 1 和 2 兩個(gè)不同的序號。
功能對比與應(yīng)用場景
| 函數(shù) | 并列處理 | 排名是否連續(xù) | 主要應(yīng)用場景 |
|---|---|---|---|
RANK() | 排名相同 | 不連續(xù) (跳躍) | 體育賽事等傳統(tǒng)排名 |
DENSE_RANK() | 排名相同 | 連續(xù) (無間隙) | 榜單排名,要求名次緊湊 |
ROW_NUMBER() | 無并列排名 | 連續(xù) | 分組獲取 Top N 記錄,數(shù)據(jù)去重 |
在實(shí)際應(yīng)用中,應(yīng)根據(jù)排名是否需要處理并列以及名次序列是否需要連續(xù)來選擇合適的函數(shù)。
到此這篇關(guān)于MySQL8 排名窗口函數(shù)實(shí)戰(zhàn)的文章就介紹到這了,更多相關(guān)MySQL8 排名窗口函數(shù)內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
Mysql數(shù)據(jù)庫雙機(jī)熱備難點(diǎn)分析
本文主要給大家介紹了在Mysql數(shù)據(jù)庫雙機(jī)熱備其中的難點(diǎn)分析以及重要環(huán)節(jié)的經(jīng)驗(yàn)心得,需要的朋友收藏分享下吧。2017-12-12
MySQL綠色版設(shè)置編碼以及1067錯(cuò)誤詳解
這篇文章主要介紹了MySQL綠色版設(shè)置編碼,以及1067錯(cuò)誤的相關(guān)資料,需要的朋友可以參考下2017-05-05
MySQL表數(shù)據(jù)文件損壞導(dǎo)致數(shù)據(jù)庫無法啟動的原因與解決方案
在日常的數(shù)據(jù)庫管理中,遇到MySQL表數(shù)據(jù)文件損壞的情況并不罕見,這種情況下,MySQL數(shù)據(jù)庫可能會無法正常啟動,給業(yè)務(wù)運(yùn)行帶來嚴(yán)重影響,本文將探討如何診斷和解決MySQL表數(shù)據(jù)文件損壞導(dǎo)致的數(shù)據(jù)庫無法啟動問題,需要的朋友可以參考下2025-03-03
MySQL系統(tǒng)庫之performance_schema的實(shí)現(xiàn)
performance_schema用于收集和存儲關(guān)于數(shù)據(jù)庫性能和資源利用情況的信息,本文主要介紹了MySQL系統(tǒng)庫之performance_schema的實(shí)現(xiàn),具有一定的參考價(jià)值,感興趣的可以了解一下2023-11-11

