SqlServer 分页存储过程
来源: 阅读:672 次 日期:2014-11-03 11:50:42
温馨提示: 小编为您整理了“SqlServer 分页存储过程”,方便广大网友查阅!

SqlServer 分页存储过程

create proc [dbo].[proc_Opinion_BaseInfo]

@TableName varchar(4000),

@PkField varchar(100),

@PageIndex int=1,

@PageSize int=10,

@SqlWhere nvarchar(4000),

@RowCount bigint output,

@PageCount bigint output

as

if(@SqlWhere='1')

set @SqlWhere = '1=1'

declare @sql nvarchar(4000),@start int,@end int

set @sql='select * from (select Row_NUMBER() OVER(order by'+@PkField+'desc) rowId,* from'+@TableName+'where'+@SqlWhere

set @start = (@PageIndex-1)*@PageSize+1

set @end = @start+@PageSize-1

set @sql = @sql + ') t where rowId between '+CAST(@start as varchar(20))+' and ' +CAST(@end as varchar(20))

exec (@sql)

set @sql = 'select @RowCount=count(1) from'+@TableName+'where'+@SqlWhere

exec sp_executesql @sql,N'@RowCount bigint OUTPUT',@RowCount OUTPUT

if(@RowCount%@PageSize=0)

begin

set @PageCount = @RowCount / @PageSize

end

else

begin

set @PageCount = @RowCount / @PageSize +1

end

更多信息请查看IT技术专栏

更多信息请查看 数据库
手机网站地址: SqlServer 分页存储过程
由于各方面情况的不断调整与变化, 提供的所有考试信息和咨询回复仅供参考,敬请考生以权威部门公布的正式信息和咨询为准!
关于我们| 联系我们| 人才招聘| 网站声明| 网站帮助| 非正式的简要咨询| 简要咨询须知| 加入群交流| 手机站点| 投诉建议
工业和信息化部备案号:滇ICP备2023014141号-1 云南省教育厅备案号:云教ICP备0901021 滇公网安备53010202001879号 人力资源服务许可证:(云)人服证字(2023)第0102001523号
云南网警备案专用图标
联系电话:0871-65317125(9:00—18:00) 获取招聘考试信息及咨询关注公众号:
咨询QQ:526150442(9:00—18:00) 版权所有:
云南网警报警专用图标
Baidu
map