通用分页存储过程


CREATE  PROCEDURE pagination
@tblName varchar(255), -- 表名
@strGetFields varchar(1000) = '*', -- 需要返回的列
@fldName varchar(255)='', -- 排序的字段名
@KeyName varchar(255)='',--关键字段
@PageSize int = 10, -- 页尺寸
@PageIndex int = 1, -- 页码
@strWhere varchar(1500) = '' -- 查询条件 (注意: 不要加 where)
AS
declare @strSQL varchar(5000) -- 主语句
declare @strOrder varchar(400) -- 排序类型
begin
  
begin
set @strOrder = " order by " + @fldName
       --如果@OrderType不是0,就执行降序,这句很重要!
end
  
if @PageIndex = 1
  begin
        if @strWhere != ''
           set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from [" + @tblName + "] where "+@strWhere+"  "+ @strOrder
        else
           set @strSQL = "select top " + str(@PageSize) +" "+@strGetFields+ " from ["+ @tblName + "] "+ @strOrder
           --如果是第一页就执行以上代码,这样会加快执行速度
  end
else
        begin
        --以下代码赋予了@strSQL以真正执行的SQL代码
        set @strSQL ="SELECT * FROM (SELECT TOP " + str(@PageSize) +" "+@strGetFields+ "  FROM " + @tblName + "  WHERE " + @KeyName + " NOT IN  ( SELECT TOP " + str(@PageSize*(@PageIndex-1)) +" " + @KeyName + "  FROM " + @tblName + " " + @strOrder + ") " + @strOrder + ")  tempa "
        if @strWhere != ''
        set @strSQL ="SELECT * FROM (SELECT TOP " + str(@PageSize) +" "+@strGetFields+ "  FROM " + @tblName + "  WHERE " + @KeyName + " NOT IN  ( SELECT TOP " + str(@PageSize*(@PageIndex-1)) +" " + @KeyName + "  FROM " + @tblName + " where  "+ @strWhere + " " + @strOrder + ")  and " + @strWhere + " " + @strOrder + ") tempa"
        end
end
exec (@strSQL)
GO
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值