好湿?好紧?好多水好爽自慰,久久久噜久噜久久综合,成人做爰A片免费看黄冈,机机对机机30分钟无遮挡

主頁 > 知識庫 > SQL中Group分組獲取Top N方法實現可首選row_number

SQL中Group分組獲取Top N方法實現可首選row_number

熱門標簽:電銷外呼系統軟件功能 咸陽電腦外呼系統運營商 怎么給高德做地圖標注 承德地圖標注公司名需要花錢嗎 慶陽地圖標注 浙江穩定外呼系統供應商 北京400電話辦理多少錢 美團地圖標注商戶認證注冊 榕城市地圖標注
有產品表,包含id,name,city,addtime四個字段,因報表需要按城市分組,統計每個城市的最新10個產品,便向該表中插入了100萬數據,做了如下系列測試:
復制代碼 代碼如下:

CREATE TABLE [dbo].[products](
[id] [int] IDENTITY(1,1) NOT NULL,
[name] [nvarchar](50) NULL,
[addtime] [datetime] NULL,
[city] [nvarchar](10) NULL,
CONSTRAINT [PK_products] PRIMARY KEY CLUSTERED
(
[id] ASC
)WITH (PAD_INDEX = OFF, STATISTICS_NORECOMPUTE = OFF, IGNORE_DUP_KEY = OFF, ALLOW_ROW_LOCKS = ON, ALLOW_PAGE_LOCKS = ON) ON [PRIMARY]
) ON [PRIMARY]

1、采用row_number方法,執行5次,平均下來8秒左右,速度最快。
復制代碼 代碼如下:

select no, id,name,city
from (select no =row_number() over (partition by city order by addtime desc), * from products)t
where no 11 order by city asc,addtime desc

2、采用cross apply方法,執行了3次,基本都在3分5秒以上,已經很慢了。
復制代碼 代碼如下:

select distinct b.id,b.name,b.city from products a
cross apply (select top 10 * from products where city = a.city order by addtime desc) b

3、采用Count查詢,只執行了兩次,第一次執行到5分鐘時,取消任務執行了;第二次執行到13分鐘時,沒有hold住又直接停止了,實在無法忍受。
復制代碼 代碼如下:

select id,name,city from products a
where ( select count(city) from products where a.city = city and addtime>a.addtime) 10
order by city asc,addtime desc

4、采用游標方法,這個最后測試的,執行了5次,每次都是10秒完成,感覺還不錯。
復制代碼 代碼如下:

declare @city nvarchar(10)
create table #Top(id int,name nvarchar(50),city nvarchar(10),addtime datetime)
declare mycursor cursor for
select distinct city from products order by city asc
open mycursor
fetch next from mycursor into @city
while @@fetch_status =0
begin
insert into #Top
select top 10 id,name,city,addtime from products where city = @city
fetch next from mycursor into @city
end
close mycursor
deallocate mycursor
Select * from #Top order by city asc,addtime desc
drop table #Top

通過上述對比不難發現,在面臨Group獲取Top N場景時,可以首選row_number,游標cursor其次,另外兩個就基本不考慮了,數據量大的時候根本沒法使用。
您可能感興趣的文章:
  • sql分組后二次匯總(處理表重復記錄查詢和刪除)的實現方法
  • SQL SERVER 分組求和sql語句
  • 顯示同一分組中的其他元素的sql語句
  • sql獲取分組排序后數據的腳本
  • SQL進行排序、分組、統計的10個新技巧分享
  • SQL分組排序去重復的小實例
  • 以數據庫字段分組顯示數據的sql語句(詳細介紹)
  • Sql Server:多行合并成一行,并做分組統計的兩個方法
  • Sql Server 分組統計并合計總數及WITH ROLLUP應用
  • SQL語句分組獲取記錄的第一條數據的方法
  • sqlserver巧用row_number和partition by分組取top數據
  • 一句Sql把縱向表轉為橫向表,并分別分組求平均和總平均值
  • sql 分組查詢問題
  • SQLserver 實現分組統計查詢(按月、小時分組)
  • 分組后分組合計以及總計SQL語句(稍微整理了一下)

標簽:昭通 呼和浩特 新鄉 重慶 貴州 上海 拉薩 江蘇

巨人網絡通訊聲明:本文標題《SQL中Group分組獲取Top N方法實現可首選row_number》,本文關鍵詞  SQL,中,Group,分組,獲取,Top,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《SQL中Group分組獲取Top N方法實現可首選row_number》相關的同類信息!
  • 本頁收集關于SQL中Group分組獲取Top N方法實現可首選row_number的相關信息資訊供網民參考!
  • 推薦文章
    主站蜘蛛池模板: 一级待一黄aaa大片在线还看| 国产午夜Av无码无片久蜜| 老师办公室高h文小说| 狗男人苏玛丽| 国产91?精彩刺激孕妇| 男同志网站XXXGAY| 99热com| 妺妺好紧好湿好滑好滑视频| 久久怡红院国产精品| 日本女人www| 黄手帕韩剧| 好大?好爽?再深一点gif小说| 免费观看又色又爽又黄的忠诚| 美国一级伧理大片| 厨房挺进同学麻麻| 国产激情视频一区二区三区| 日本人妻中文字幕无码一区二区| 国产高清在线91福利| 肉嫁高柳家在线播放| 欧美黑人狂躁日本妞| 欧美天天澡天天爽日日a| 女高中生被调教侵犯在线观看| 制服丝袜护士久久久久久| 中文字幕在线观看一区二区三区| 电影《丰满的人妻》| 国产丰满美女A级毛片仙踪林| 美女脱去衣服的照片| 女尊np肉多荤文高h| aa在线视频| free欧美Ass性HD| 黑帮大佬和我的365日第二部在线观看 | 国产做受???高潮| 免费稚嫩福利| 尤物在线播放| 强制调教vk| futa全肉H文| 午夜剧场三级| 日本动漫看片黄a免费看| 两个人看的视频日本动漫| 两个女人的诱惑在线观看| 青草视频免费观看在线观看|