你好,欢迎来到电脑编程技巧与维护杂志社! 杂志社简介广告服务读者反馈编程社区  
合订本订阅
 
 
您的位置:技术专栏 / 数据库开发
Sql分页查询效率分析
 

选取了2中效率比较高的方式比较效率:row_Number() 、offset fetch

表test中有1000条数据,2个字段:field1(int),field2(nvarchar)

--1000条数据,查询500次第1-10行,39s
--1000条数据,查询500次第500-550行,87s
--1000条数据,查询500次第150-160行,88s
DECLARE @uId int
SET @uId=1 BEGIN while @uId<=500 BEGIN
SELECT *
FROM (
SELECT row_number() over(
ORDER BY [dbo].[test].[filed1] desc) as rownum,* from [dbo].[test]) temp
WHERE temp.rownum BETWEEN 150 AND 160;


SET @uId=@uId+1 END END;

--1000条数据,查询500次第1-10行,78s
--1000条数据,查询500次第500-550行,78s
DECLARE @uId int
SET @uId=1 BEGIN while @uId<=500 BEGIN
SELECT *
FROM [dbo].[test]
ORDER BY [dbo].[test].[filed1] DESC
OFFSET (10 * (15 - 1)) ROWS FETCH NEXT 10 ROWS ONLY
SET @uId=@uId+1 END END

测试效果:

row_Number()不稳定,考前的记录查询比较快,靠后的记录查询时间会增加

OFFSET FETCH 稳定,考前靠后的查询时间都是基本一样

  推荐精品文章

·2024年12月目录 
·2024年11月目录 
·2024年10月目录 
·2024年9月目录 
·2024年8月目录 
·2024年7月目录 
·2024年6月目录 
·2024年5月目录 
·2024年4月目录 
·2024年3月目录 
·2024年2月目录 
·2024年1月目录
·2023年12月目录
·2023年11月目录

  联系方式
TEL:010-82561037
Fax: 010-82561614
QQ: 100164630
Mail:gaojian@comprg.com.cn

  友情链接
 
Copyright 2001-2010, www.comprg.com.cn, All Rights Reserved
京ICP备14022230号-1,电话/传真:010-82561037 82561614 ,Mail:gaojian@comprg.com.cn
地址:北京市海淀区远大路20号宝蓝大厦E座704,邮编:100089