亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

sqlserver巧用row_number和partition by分組取top數(shù)據(jù)

 更新時(shí)間:2011年12月20日 11:55:07   作者:  
SQL Server 2005后之后,引入了row_number()函數(shù),row_number()函數(shù)的分組排序功能使這種操作變得非常簡(jiǎn)單
分組取TOP數(shù)據(jù)是T-SQL中的常用查詢, 如學(xué)生信息管理系統(tǒng)中取出每個(gè)學(xué)科前3名的學(xué)生。這種查詢?cè)赟QL Server 2005之前,寫(xiě)起來(lái)很繁瑣,需要用到臨時(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ù)的唯一的)

相關(guān)文章

最新評(píng)論