SQL分页存储过程

自己写的一个SQL分页存储过程,原理来自网上的一篇文章,
原理为:
select top 页大小 *
from table1
where id >
(
select max (id) from
(
select top ((页码 - 1 ) * 页大小) id from table1 order by id) as T
)



CREATE procedure GetLYZXNews
@type int , -- 文章类型
@Pgs int , -- 页大小
@Pgn int -- 页码,页码为0则为求总页数
as
declare @strsql varchar ( 500 ) -- 执行的SQL语句
declare @ZongShu int -- 记录总数
declare @YeShu int -- 总页数
declare @strTmp int -- 临时变量
if @Pgn = 0
    
begin
    
select @ZongShu = count ( * ) from LYNews where type = @type
    
if @ZongShu <= @Pgs
      
begin
        
if @ZongShu = 0
          
begin
                
set @YeShu = 0
              
end
            
else
              
begin
                
Set @YeShu = 1
              
end
      
end
    
else
          
begin
            
set @strTmp = @ZongShu % @Pgs
            
if @strTmp = 0
            
begin
              
set @YeShu = @ZongShu / @Pgs
            
end
            
else
            
begin
              
set @YeShu = @ZongShu / @Pgs + 1
            
end
          
end
        
set @strsql = " select " + str ( @ZongShu ) + " as ZongShu," + str ( @YeShu ) + " as YeShu"
    
end
else
    
begin
    
if @Pgn = 1
begin
set    @strsql = " select top " + str ( @Pgs ) + " * from LyNews Where type = " + str ( @type ) + " order by postDate desc "
end
else
begin
set @strsql = " select top " + str ( @Pgs ) + " * from LyNews Where type = " + str ( @type ) + " and postDate < ( select min (postDate) from "
set @strsql = @strsql + "( select top " + str (( @Pgn - 1 ) * @Pgs ) + " * from LyNews where type = " + str ( @type ) + " order by postdate desc ) as t) order by postDate desc "
end
    
end
exec ( @strSQL )
GO
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值