• 欢迎访问搞代码网站,推荐使用最新版火狐浏览器和Chrome浏览器访问本网站!
  • 如果您觉得本站非常有看点,那么赶紧使用Ctrl+D 收藏搞代码吧

发布一个高效的数据分页的存储过程 可以_sqlserver

sqlserver 搞代码 3年前 (2018-06-16) 72次浏览 已收录 0个评论

CREATE PROCEDURE pageTest  –用于翻页的测试
–需要把排序字段放在第一列

 (
  @FirstID nvarchar(20)=null,  –当前页面里的第一条记录的排序字段的值
  @LastID nvarchar(20)=null,  –当前页面里的最后一条记录的排序字段的值
  @isNext bit=null,    –true 1 :下一页;false 0:上一页
  @allCount int output,   –返回总记录数

http://www.gaodaima.com/36194.html发布一个高效的数据分页的存储过程 可以_sqlserver

  @pageSize int output,   –返回一页的记录数
  @CurPage int     –页号(第几页)0:第一页;-1最后一页。
  )

AS

if @CurPage=0
 begin
  –统计总记录数
  select @allCount=count(ProductId) from Product_test
  
  set @pageSize=10
  –返回第一页的数据
  select top 10
   ProductId,
   ProductName,
   Introduction  
   from Product_test order by ProductId
 end

else if @CurPage=-1

 select * from
  (select top 10 ProductId,
   ProductName,
   Introduction

  from Product_test order by ProductId desc ) as aa 
  order by ProductId
else

 begin
  if @isNext=1
   –翻到下一页
   select top 10 ProductId,
   ProductName,
   Introduction
  from Product_test where ProductId > @LastID order by ProductId
  
  
  else
   –翻到上一页
   select * from
    (select top 10 ProductId,
   ProductName,
   Introduction
  from Product_test where ProductId < @FirstID  order by ProductId desc) as bb order by ProductId
 end
 

百万数据翻页就像100条数据一样!

http://www.jyklzz.net/web/jyk/index.asp 这里有详细的说明

 

 

欢迎大家阅读《发布一个高效的数据分页的存储过程 可以_sqlserver,跪求各位点评,若觉得好的话请收藏本文,by 搞代码


喜欢 (0)
[搞代码]
分享 (0)
发表我的评论
取消评论

表情 贴图 加粗 删除线 居中 斜体 签到

Hi,您需要填写昵称和邮箱!

  • 昵称 (必填)
  • 邮箱 (必填)
  • 网址