sqlserver 三种分页方式性能比较[图文]

来源:asp之家 时间:2011-09-30 11:16:20 

Liwu_Items表,CreateTime列建立聚集索引

第一种,sqlserver2005特有的分页语法

代码如下:


declare @page int
declare @pagesize int
set @page = 2
set @pagesize = 12

SET STATISTICS IO on
SELECT a.* FROM (
SELECT ROW_NUMBER() OVER (ORDER BY b.CreateTime DESC) AS [ROW_NUMBER], b.*
FROM [dbo].[Liwu_Items] AS b ) AS a
WHERE a.[ROW_NUMBER] BETWEEN @pagesize + 1 AND (@page*@pagesize)
ORDER BY a.[ROW_NUMBER]


结果:

(12 行受影响)表 'Liwu_Items'。扫描计数 1,逻辑读取 7 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
  逻辑读是7次

执行计划:

主要开销都在聚集索引扫描了。

第二种,用两个top分别正序和倒序排列,共另个子查询来实现分页,

代码如下:


declare @page int
declare @pagesize int
set @page = 2
set @pagesize = 12

SET STATISTICS IO on
select * from (
select top (@pagesize) * from
(select top (@page*@pagesize) * from Liwu_Items order by CreateTime desc) a
order by CreateTime asc) b
order by CreateTime desc


结果

(12 行受影响)表 'Liwu_Items'。扫描计数 1,逻辑读取 7 次,物理读取 0 次,预读 317 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
  执行计划

执行计划和第一种差不多,但两个排序占的资源挺多的。

第三种,最垃圾的一种,用not in字句实现的,如下

代码如下:


declare @page int
declare @pagesize int
set @page = 2
set @pagesize = 12

SET STATISTICS IO on
select top(@pagesize) * from Liwu_Items
where ItemId not in(
select top((@page-1)*@pagesize) ItemId from Liwu_Items order by CreateTime desc)
order by CreateTime Desc


结果

(12 行受影响)表 'Worktable'。扫描计数 1,逻辑读取 70 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。表 'Liwu_Items'。扫描计数 2,逻辑读取 18 次,物理读取 0 次,预读 0 次,lob 逻辑读取 0 次,lob 物理读取 0 次,lob 预读 0 次。
  性能最差,对两个表进行处理,逻辑读都很高,汗。

执行计划

这执行计划都看不懂,嵌套循环和表假脱机占了很大的资源。


总结:第二种分页方法和第一种分页方法效率差不多,但第二种可用于老版本的sqlserver甚至access,最后一种别用。

标签:分页方式,性能比较
0
投稿

猜你喜欢

  • CSS结合js实现动态更换皮肤

    2007-07-14 10:01:00
  • 名词解释:带你轻松接触13个数据库术语

    2009-05-13 10:32:00
  • 如何把小写数字转换成英文?

    2009-11-06 13:59:00
  • ASP 支持中文的len(),left(),right()的函数代码

    2011-03-03 10:59:00
  • 每个分类取最新的几条的SQL实现代码

    2012-08-21 10:57:18
  • 利用色轮选择颜色搭配[译]

    2009-10-31 18:24:00
  • 说说CSS Hack 和向后兼容

    2010-05-17 13:11:00
  • 如果没设置 DSN 也能建立数据库连接吗?

    2009-11-02 20:16:00
  • 从if else到switch case再到抽象

    2010-11-05 18:30:00
  • 谷歌历年母亲节Logo一览

    2009-05-11 12:17:00
  • sql ntext数据类型字符替换实现代码

    2011-09-30 11:08:00
  • asp如何读取服务器上的驱动器?

    2009-11-18 20:50:00
  • 从Vista地址栏到网站导航菜单

    2009-09-08 12:35:00
  • 基于Oracle的面向对象技术入门基础简析开发者网络Oracle

    2010-07-18 12:57:00
  • 用VBS语言实现的网页计算器源代码

    2007-12-26 17:09:00
  • 扩展数据库系统选项实现更高的可扩展性

    2009-01-06 11:14:00
  • 如何将服务器端变量转换为客户端的变量?

    2009-12-03 19:54:00
  • ADO组件之插入数据记录

    2008-10-08 12:21:00
  • 如何检测Oracle的ODBC是否连接成功?

    2009-11-24 20:31:00
  • 观点 2009 年,IE6 走好

    2009-01-04 16:46:00
  • asp之家 网络编程 m.aspxhome.com