標籤:log rom .net subject dem 管理系統 creat des 學生資訊管理系統
SQL Server 2005後之後,引入了row_number()函數,row_number()函數的分組排序功能使這種操作變得非常簡單
分組取TOP資料是T-SQL中的常用查詢, 如學生資訊管理系統中取出每個學科前3名的學生。這種查詢在SQL Server 2005之前,寫起來很繁瑣,需要用到暫存資料表關聯查詢才能取到。SQL Server 2005後之後,引入了row_number()函數,row_number()函數的分組排序功能使這種操作變得非常簡單。下面是一個簡單樣本:
--1.建立測試表
create table #score
(
name varchar(20),
subject varchar(20),
score int
)
--2.插入測試資料
insert into #score(name,subject,score) values(‘張三‘,‘語文‘,98)
insert into #score(name,subject,score) values(‘張三‘,‘數學‘,80)
insert into #score(name,subject,score) values(‘張三‘,‘英語‘,90)
insert into #score(name,subject,score) values(‘李四‘,‘語文‘,88)
insert into #score(name,subject,score) values(‘李四‘,‘數學‘,86)
insert into #score(name,subject,score) values(‘李四‘,‘英語‘,88)
insert into #score(name,subject,score) values(‘李明‘,‘語文‘,60)
insert into #score(name,subject,score) values(‘李明‘,‘數學‘,86)
insert into #score(name,subject,score) values(‘李明‘,‘英語‘,88)
insert into #score(name,subject,score) values(‘林風‘,‘語文‘,74)
insert into #score(name,subject,score) values(‘林風‘,‘數學‘,99)
insert into #score(name,subject,score) values(‘林風‘,‘英語‘,59)
insert into #score(name,subject,score) values(‘嚴明‘,‘英語‘,96)
--3.取每個學科的前3名資料
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.刪除暫存資料表
truncate table #score
drop table #score
文法形式:ROW_NUMBER() OVER(PARTITION BY COL1 ORDER BY COL2)
解釋:根據COL1分組,在分組內部根據 COL2排序,而此Function Compute的值就表示每組內部排序後的順序編號(組內連續的唯一的)
轉自:http://blog.csdn.net/zengcong2013/article/details/45833363
sql 分組取最新的資料sqlserver巧用row_number和partition by分組取top資料