主頁(yè) > 知識(shí)庫(kù) > sqlserver巧用row_number和partition by分組取top數(shù)據(jù)

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

熱門標(biāo)簽:江西穩(wěn)定外呼系統(tǒng)供應(yīng)商 北京智能外呼系統(tǒng)供應(yīng)商家 奧維地圖標(biāo)注字體大小修改 電話機(jī)器人錄音師薪資 無錫梁溪公司怎樣申請(qǐng)400電話 中國(guó)地圖標(biāo)注省份用什么符號(hào) 高德地圖標(biāo)注電話怎么沒了 孝感銷售電銷機(jī)器人廠家 智能電銷機(jī)器人教育
分組取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è)查詢的用法詳解

標(biāo)簽:荊州 阜陽(yáng) 臨滄 通化 那曲 泰州 齊齊哈爾 海北

巨人網(wǎng)絡(luò)通訊聲明:本文標(biāo)題《sqlserver巧用row_number和partition by分組取top數(shù)據(jù)》,本文關(guān)鍵詞  sqlserver,巧用,row,number,和,;如發(fā)現(xiàn)本文內(nèi)容存在版權(quán)問題,煩請(qǐng)?zhí)峁┫嚓P(guān)信息告之我們,我們將及時(shí)溝通與處理。本站內(nèi)容系統(tǒng)采集于網(wǎng)絡(luò),涉及言論、版權(quán)與本站無關(guān)。
  • 相關(guān)文章
  • 下面列出與本文章《sqlserver巧用row_number和partition by分組取top數(shù)據(jù)》相關(guān)的同類信息!
  • 本頁(yè)收集關(guān)于sqlserver巧用row_number和partition by分組取top數(shù)據(jù)的相關(guān)信息資訊供網(wǎng)民參考!
  • 推薦文章