sqlserver巧用row_number和partition by分組取top數(shù)據(jù)
更新時(shí)間:2011年12月20日 11:55:07 作者:
SQL Server 2005后之后,引入了row_number()函數(shù),row_number()函數(shù)的分組排序功能使這種操作變得非常簡單
分組取TOP數(shù)據(jù)是T-SQL中的常用查詢, 如學(xué)生信息管理系統(tǒng)中取出每個(gè)學(xué)科前3名的學(xué)生。這種查詢在SQL Server 2005之前,寫起來很繁瑣,需要用到臨時(shí)表關(guān)聯(lián)查詢才能取到。SQL Server 2005后之后,引入了row_number()函數(shù),row_number()函數(shù)的分組排序功能使這種操作變得非常簡單。下面是一個(gè)簡單示例:
--1.創(chuàng)建測試表
create table #score
(
name varchar(20),
subject varchar(20),
score int
)
--2.插入測試數(shù)據(jù)
insert into #score(name,subject,score) values('張三','語文',98)
insert into #score(name,subject,score) values('張三','數(shù)學(xué)',80)
insert into #score(name,subject,score) values('張三','英語',90)
insert into #score(name,subject,score) values('李四','語文',88)
insert into #score(name,subject,score) values('李四','數(shù)學(xué)',86)
insert into #score(name,subject,score) values('李四','英語',88)
insert into #score(name,subject,score) values('李明','語文',60)
insert into #score(name,subject,score) values('李明','數(shù)學(xué)',86)
insert into #score(name,subject,score) values('李明','英語',88)
insert into #score(name,subject,score) values('林風(fēng)','語文',74)
insert into #score(name,subject,score) values('林風(fēng)','數(shù)學(xué)',99)
insert into #score(name,subject,score) values('林風(fēng)','英語',59)
insert into #score(name,subject,score) values('嚴(yán)明','英語',96)
--3.取每個(gè)學(xué)科的前3名數(shù)據(jù)
select * from
(
select subject,name,score,ROW_NUMBER() over(PARTITION by subject order by score desc) as num from #score
) T where T.num <= 3 order by subject
--4.刪除臨時(shí)表
truncate table #score
drop table #score
語法形式:ROW_NUMBER() OVER(PARTITION BY COL1 ORDER BY COL2)
解釋:根據(jù)COL1分組,在分組內(nèi)部根據(jù) COL2排序,而此函數(shù)計(jì)算的值就表示每組內(nèi)部排序后的順序編號(hào)(組內(nèi)連續(xù)的唯一的)
復(fù)制代碼 代碼如下:
--1.創(chuàng)建測試表
create table #score
(
name varchar(20),
subject varchar(20),
score int
)
--2.插入測試數(shù)據(jù)
insert into #score(name,subject,score) values('張三','語文',98)
insert into #score(name,subject,score) values('張三','數(shù)學(xué)',80)
insert into #score(name,subject,score) values('張三','英語',90)
insert into #score(name,subject,score) values('李四','語文',88)
insert into #score(name,subject,score) values('李四','數(shù)學(xué)',86)
insert into #score(name,subject,score) values('李四','英語',88)
insert into #score(name,subject,score) values('李明','語文',60)
insert into #score(name,subject,score) values('李明','數(shù)學(xué)',86)
insert into #score(name,subject,score) values('李明','英語',88)
insert into #score(name,subject,score) values('林風(fēng)','語文',74)
insert into #score(name,subject,score) values('林風(fēng)','數(shù)學(xué)',99)
insert into #score(name,subject,score) values('林風(fēng)','英語',59)
insert into #score(name,subject,score) values('嚴(yán)明','英語',96)
--3.取每個(gè)學(xué)科的前3名數(shù)據(jù)
select * from
(
select subject,name,score,ROW_NUMBER() over(PARTITION by subject order by score desc) as num from #score
) T where T.num <= 3 order by subject
--4.刪除臨時(shí)表
truncate table #score
drop table #score
語法形式:ROW_NUMBER() OVER(PARTITION BY COL1 ORDER BY COL2)
解釋:根據(jù)COL1分組,在分組內(nèi)部根據(jù) COL2排序,而此函數(shù)計(jì)算的值就表示每組內(nèi)部排序后的順序編號(hào)(組內(nèi)連續(xù)的唯一的)
相關(guān)文章
SQLServer 2005 列所有存儲(chǔ)過程的語句
對(duì)于數(shù)據(jù)庫管理員來說,可以經(jīng)常想了解一些之前未聽說過的存儲(chǔ)過程,特別是無文檔類型的存儲(chǔ)過程?;蛟S是用這些存儲(chǔ)過程,能夠簡化日常的數(shù)據(jù)管理。2008-11-11
配置 SQLServer2005 以允許遠(yuǎn)程連接
為 SQL Server 2005 Express Edition 或 SQL Server 2005 Developer Edition 啟用遠(yuǎn)程連接/2009-11-11
sqlserver2005 TSql新功能學(xué)習(xí)總結(jié)(數(shù)據(jù)類型篇)
sql server2005 TSql新功能學(xué)習(xí)總結(jié)(數(shù)據(jù)類型篇) ,希望對(duì)需要的朋友有所幫助。2010-07-07
Win2008中SqlServer2008 無法打開錯(cuò)誤日志文件導(dǎo)致無法啟動(dòng)的解決方法
今天早上一個(gè)客戶的SqlServer 2008的服務(wù)器應(yīng)為重新修改配置導(dǎo)致網(wǎng)站打不開,提示initerrlog: 無法打開錯(cuò)誤日志文件2011-12-12
SQL2005 provider: 命名管道提供程序 error: 40 無法打開到 SQL Server 的連接
這篇文章主要介紹了SQL2005 provider: 命名管道提供程序 error: 40 無法打開到 SQL Server 的連接,需要的朋友可以參考下2015-01-01
SqlServer 2005 T-SQL Query 學(xué)習(xí)筆記(1)
SqlServer 2005 T-SQL Query 學(xué)習(xí)筆記(1)2010-02-02
Windows2003 SQL2005添加系統(tǒng)用戶修改系統(tǒng)登錄密碼
這篇文章主要介紹了Windows2003 SQL2005添加系統(tǒng)用戶修改系統(tǒng)登錄密碼的方法,大家如何忘記了系統(tǒng)的密碼可以試試這個(gè)方法2013-11-11

