分組取TOP數(shù)據(jù)是T-SQL中的常用查詢, 如學(xué)生信息管理系統(tǒng)中取出每個(gè)學(xué)科前3名的學(xué)生。這種查詢?cè)赟QL Server 2005之前,寫起來很繁瑣,需要用到臨時(shí)表關(guān)聯(lián)查詢才能取到。SQL Server 2005后之后,引入了row_number()函數(shù),row_number()函數(shù)的分組排序功能使這種操作變得非常簡(jiǎn)單。下面是一個(gè)簡(jiǎn)單示例:
復(fù)制代碼 代碼如下:
--1.創(chuàng)建測(cè)試表
create table #score
(
name varchar(20),
subject varchar(20),
score int
)
--2.插入測(cè)試數(shù)據(jù)
insert into #score(name,subject,score) values('張三','語(yǔ)文',98)
insert into #score(name,subject,score) values('張三','數(shù)學(xué)',80)
insert into #score(name,subject,score) values('張三','英語(yǔ)',90)
insert into #score(name,subject,score) values('李四','語(yǔ)文',88)
insert into #score(name,subject,score) values('李四','數(shù)學(xué)',86)
insert into #score(name,subject,score) values('李四','英語(yǔ)',88)
insert into #score(name,subject,score) values('李明','語(yǔ)文',60)
insert into #score(name,subject,score) values('李明','數(shù)學(xué)',86)
insert into #score(name,subject,score) values('李明','英語(yǔ)',88)
insert into #score(name,subject,score) values('林風(fēng)','語(yǔ)文',74)
insert into #score(name,subject,score) values('林風(fēng)','數(shù)學(xué)',99)
insert into #score(name,subject,score) values('林風(fēng)','英語(yǔ)',59)
insert into #score(name,subject,score) values('嚴(yán)明','英語(yǔ)',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
語(yǔ)法形式:ROW_NUMBER() OVER(PARTITION BY COL1 ORDER BY COL2)
解釋:根據(jù)COL1分組,在分組內(nèi)部根據(jù) COL2排序,而此函數(shù)計(jì)算的值就表示每組內(nèi)部排序后的順序編號(hào)(組內(nèi)連續(xù)的唯一的)
您可能感興趣的文章:- SQLSERVER分頁(yè)查詢關(guān)于使用Top方式和row_number()解析函數(shù)的不同
- SQLServer中Partition By及row_number 函數(shù)使用詳解
- sqlServer使用ROW_NUMBER時(shí)不排序的解決方法
- sqlserver2005使用row_number() over分頁(yè)的實(shí)現(xiàn)方法
- SqlServer2005中使用row_number()在一個(gè)查詢中刪除重復(fù)記錄的方法
- SqlServer 2005中使用row_number()在一個(gè)查詢中刪除重復(fù)記錄
- SQLSERVER 2005的ROW_NUMBER、RANK、DENSE_RANK的用法
- sqlserver 通用存儲(chǔ)過程分頁(yè)代碼(附使用ROW_NUMBER()和不使用ROW_NUMBER()兩種情況性能分析)
- SQL Server中row_number分頁(yè)查詢的用法詳解