当前位置: 首页 > 图文教程 > 数据库 > MSSQL > sql server平台用存储过程进行分页的两种方法

MSSQL
SQL Server 中死锁产生的原因及解决办法
教你在SQL Server 2000数据库中使用分区
数据仓库基本报表制作过程中的SQL写法
自动定时重启sql server回收内存
轻松解决SQL Server 2005中的常见问题
用一个案例讲解SQL Server数据库恢复
安装SQL Server 2005时出现计数器错误
讲解SQL Server 2005数据库的同义词Bug
利用SQL语句对不同数据库进行高效果分页
三种数据库利用SQL语句进行高效果分页
数据库连接字符串的常见问题和解决方法
教你快速掌握一些方便易用的SQL语句
深入分析SQL Server的数据转换服务
系统默认的MySQL用户名消失的解决方法
SQL 2008邮件故障排除:发送测试电子邮件
SQL Server 2005日志文件损坏的处理方法
在SQL Server 2005数据库中进行错误捕捉
SQL Server查询速度慢原因及优化方法
加密SQL Anywhere 提升政府行业数据安全
Windows Server 2008之数据安全保护

MSSQL 中的 sql server平台用存储过程进行分页的两种方法


出处:互联网   整理: 软晨网(RuanChen.com)   发布: 2009-10-30   浏览: 128 ::
收藏到网摘: n/a

 

killergo的专栏

最近因为稍微有点空闲时间,所以想了下在sql server平台用存储过程的分页方式,现在列示在下面。

实际测试时,在15000条数据情况下两者性能大体相当,在20000-30000条数据的情况下前者明显比后者性能更佳。更大数据量没有进行测试了。

注意,数据表里面是否有 键和索引 对性能的影响相当大
-----------------------------------------------------
第一种:

/*第一个参数是每页条数,第二个参数是目标页码*/

CREATE proc sp_fixpage @pagesize int,@destpage int  as
set nocount on
declare @id int
declare @startid int

select @startid = (@destpage - 1)*@pagesize

set rowcount @startid
select @id = id from t_member

set rowcount @pagesize
set nocount off
select * from t_member where id > @id order by id
GO


第二种:

CREATE PROCEDURE sp_fixpage1 @pagesize int ,@destpage int
as
set nocount on
 
CREATE TABLE #myTable(
 [ID] [int] NOT NULL ,
 [UserName] [varchar] (50) COLLATE Chinese_PRC_CI_AS NOT NULL ,
 [Name] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
 [Origin] [int] NULL ,
 [LatencyBuyDegree] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
 [UserType] [varchar] (2) COLLATE Chinese_PRC_CI_AS NULL ,
 [Email] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
 [UserLev] [int] NULL ,
 [RegTime] [datetime] NULL ,
 [RegMode] [bit] NULL ,
 [PaperNum] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
 [UserClass] [bit] NULL ,
 [password] [binary] (64) NULL ,
 [Tel] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
 [drass] [varchar] (150) COLLATE Chinese_PRC_CI_AS NULL ,
 [Zip] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
 [PaperNumlb] [int] NULL ,
 [OpUser] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
 [Province] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
 [BirthDate] [datetime] NULL
) ON [PRIMARY]

declare @tempPos int
declare @absPos int
declare @nowID int

set @tempPos = 1
set @absPos = 1

if @destpage > 1
    set @absPos = (@pagesize*(@destpage- 1) + 1)

   declare myCursor scroll cursor for
      select [ID] from t_member order by id

open myCursor
fetch absolute @absPos from myCursor into @nowID

while (@@fetch_status = 0) and (@tempPos <= @pagesize)
begin
  set @tempPos = @tempPos + 1
  insert into #myTable select * from t_member where [ID] = @nowID
  fetch next from myCursor into @nowID
end

close myCursor
deallocate myCursor

set nocount off
 
select * from #myTable
drop table #myTable
GO