SQL实现分页

 表中主键必须为标识列,[ID] int IDENTITY (1,1)

  1、分页方案一:(利用Not In和SELECT TOP分页)

  语句形式:

SELECT TOP 10*
FROM 表
WHERE(id NOT IN
          (SELECT TOP 20 id
            FROM 表
            ORDER BY id)AST)
ORDER BY id
SELECT TOP 页记录条数*
FROM 表
WHERE(id NOT IN
           (SELECT TOP 页记录数*页数 id
             FROM 表
             ORDER BY id)AST)
ORDER BY id
 

  2、分页方案二:(利用ID大于多少和SELECT TOP分页)

  语句形式:

SELECT TOP 10*
FROM TestTable
WHERE(ID>
     (SELECTMAX(id)
    FROM(SELECTTOP20id
        FROMTestTable
        ORDERBYid)AST))
ORDERBYID
SELECTTOP页大小*
FROMTestTable
WHERE(ID>
     (SELECTMAX(id)
    FROM(SELECTTOP页大小*页数id
        FROM表
        ORDERBYid)AST))
ORDERBYID

  3、分页方案三:(利用SQL的游标存储过程分页)

create procedureSqlPager
@sqlstrnvarchar(4000),--查询字符串
@currentpageint,--第N页
@pagesizeint--每页行数
as
setnocounton
declare@P1int,--P1是游标的id
@rowcountint
execsp_cursoropen@P1output,@sqlstr,@scrollopt=1,@ccopt=1,@rowcount=@rowcountoutput
selectceiling(1.0*@rowcount/@pagesize)as总页数--,@rowcountas总行数,@currentpageas当前页
set@currentpage=(@currentpage-1)*@pagesize+1
execsp_cursorfetch@P1,16,@currentpage,@pagesize
execsp_cursorclose@P1
setnocountoff

  其它的方案:如果没有主键,可以用临时表,也可以用方案三做,但是效率会低。

  建议优化的时候,加上主键和索引,查询效率会提高。

  以上三种方案的比较:

  分页方案二:(利用ID大于多少和SELECT TOP分页)效率最高,需要拼接SQL语句

  分页方案一:(利用Not In和SELECT TOP分页) 效率次之,需要拼接SQL语句

  分页方案三:(利用SQL的游标存储过程分页) 效率最差,但是最为通用

        4、方案四:

         使用top
        1.利用当前记录号(currentnote)和分页页面大小(pagesize)进行分页

CREATE PROCDURE GetNextPageInfo2 -- 获取下一页的记录
@pagesize int, --页面记录数
@currentnote int --当前记录号
AS
   DECLARE @sql nvarchar(200) 
   SET @sql=N' select top '+ convert( varchar(10),@pagesize)+ ' * from 表 where 主键 > ' + convert( varchar(10),@currentnote) 
    EXECUTE sp_executesql @sql
GO

     2.利用本页页码和分页页面大小进行分页

CREATE PROCDURE GetNextPageInfo
@pagesize int, --每页记录数
@page int --当前页码
As
    DECLARE @jilu big int
    SET @jilu=(@pagesize*@page)
    DECLARE @sql nvarchar(200) 
    SET @sql=N'select top '+ convert(varchar(10),@pagesize)+ ' * from 表 where 主键 not in (select top ' + convert(varchar(10),@jilu) + ' 主键 from 表 order by 主键) order by 主键' 
    EXECUTE sp_executesql @sql
GO
两种方式比较:第一种执行效率应该高于第二种,不过在id号多变的情况下第二种方法使用起来相对简单。


2、 使用rowcount

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值