SQL2005基于ROW_NUMBER() 两种分页性能比

 

相比在SQL Server 2000 中使用的分页方式,在SQL Server 2005中使用新的语法ROW_NUMBER()来分页效率要高出很多,但是很多人在使用ROW_NUMBER()这种分页方式时,使用的方法并不正确,以下列出不正确的和正确的做法并做简单分析:

首先假设我们已经创建了如下的表和索引并初始化了100万条数据:

CREATE TABLE [dbo].[Users]
(
  [ID] [int] IDENTITY(1,1) NOT NULL,
  [Name] [varchar](50) NULL,
  [test] [nchar](10) NULL,
  CONSTRAINT [PK_Users] PRIMARY KEY CLUSTERED
  (
     [ID] ASC
  ) ON [PRIMARY]
) ON [PRIMARY]

CREATE UNIQUE NONCLUSTERED INDEX [Inx_Name] ON [dbo].[Users]
(
  [Name] ASC
) ON [PRIMARY]

DECLARE @index INT
SET @index=0
WHILE @index<1000000
BEGIN
        INSERT INTO Users(Name,test) values(@index,'walkingp')
  SET @index = @index + 1
END 

不正确的使用方式(查出所有数据后再排序):

select Id,Name,test from (select row_number() over(order by name) as rowNum,* from users) as t where rowNum between 5000 and 5100 

正确的使用方式如下(查出主键进行排序过滤,然后使用过滤后的主键来查找数据):

select a.Id,a.Name,a.test  from users as a inner join (select rowNum,id from (select row_number() over(order by name) as rowNum,ID from users) as t where rowNum between 4000 and 4100) as b on a.id = b.id order by b.rownum

以下具体分析:

set statistics io on
set statistics time on

go
print 'Error.5000-------------------------'
declare @time datetime 
declare @ms int
set @time= getdate() 

select Id,Name,test from (select row_number() over(order by name) as rowNum,* from users) as t where rowNum between 5000 and 5100 

set @ms=datediff(ms,@time,getdate()) 
print @ms--毫秒数

go
print 'Right.5000-------------------------'
declare @time datetime 
declare @ms int
set @time= getdate() 

select a.Id,a.Name,a.test  from users as a inner join (select rowNum,id from (select row_number() over(order by name) as rowNum,ID from users) as t where rowNum between 5000 and 5100) as b on a.id = b.id order by b.rownum

set @ms=datediff(ms,@time,getdate()) 
print @ms--毫秒数

go

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值