SQLServer分页存储过程

参考别人的写了一个分页存贮过程,备以后用

创建存贮过程:

Create PROCEDURE [dbo].[UP_GetRecordByPage]
@tblName   varchar(255),       -- 表名
@fldName varchar(1000) = '*', -- 需要返回的列,默认*
@strOrder varchar(255)='',      -- 排序的字段名,必填。后面跟着排序方式,如UserName Desc ,多个排序字段用逗号分开,
@PageSize   int = 10,          -- 页尺寸,默认10
@PageIndex int = 1,           -- 页码,默认1
@strWhere varchar(1500) = '', -- 查询条件 (注意: 不要加 where)
@TotalCount int output        --返回记录总数
AS

declare @strSQL   varchar(5000)
declare @totalSql nvarchar(4000)
if @strWhere !=''
set @strWhere=' where '+@strWhere

--总记录数
set @totalSql='SELECT @TotalCount=COUNT(*) FROM '+@tblName+' '+@strWhere
exec sp_executesql @totalSql,N'@TotalCount int OUTPUT',@TotalCount OUTPUT

set @strSQL=
'SELECT * FROM ('+
 'SELECT ROW_NUMBER() OVER (ORDER BY '+@strOrder+') AS pos,'+@fldName+' '+
 'FROM '+@tblName+' '+@strWhere+
') AS sp WHERE pos BETWEEN '+str((@PageIndex-1)*@PageSize+1)+' AND '+str(@PageIndex*@PageSize)
 
exec (@strSQL)

 

备注:记录总数是以output参数返回

使用测试:

declare @count int
exec UP_GetRecordByPage
'UserInfo','*','UserName desc',10,1,'',@count output ;
print @count;

转载于:https://www.cnblogs.com/hanshuhe/archive/2011/10/11/2207677.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值