显示分页

--信息列表分页
if exists (select * from sysobjects where name = 'up_fen')
drop proc up_fen
go


create proc up_fen
@tableName varchar(8000), --表名、视图名
@indexCol varchar(50) = '', --标识列名(如:比如主键、标识,推荐使用索引列)
@pageSize int = 10, --页面大小
@pageIndex int = 1, --当前页
@orderCol varchar(100) = 'desc',--排序 (如:id)
@where varchar(max) = '1=1', --条件
@columns varchar(500) = '*' --要显示的列
as
declare @sql varchar(max)
declare @sql2 varchar(max)

if @where <> ''
begin
select @sql2='select count('+@columns+') from '+@tableName+' where '+ @where
select @sql='select '+ @columns+ ' from '+ @tableName+' where '+ @where +' order by '+ (@indexCol)+' '+@orderCol+''+ ' offset ' +Convert(varchar(10),((@pageIndex-1)*@pageSize))+ ' row fetch next ' + Convert(varchar(10),(@pageSize))+ ' row only'

end
else
begin
select @sql2='select count('+@columns+') from '+@tableName
select @sql2='select count('+@columns+') from '+@tableName
select @sql='select '+ @columns+ ' from '+ @tableName+' order by '+ (@indexCol)+' '+@orderCol+''+ ' offset ' +Convert(varchar(10),((@pageIndex-1)*@pageSize))+ ' row fetch next ' + Convert(varchar(10),@pageSize)+ ' row only'
end

exec (@sql)
PRINT @sql
exec (@sql2)
PRINT @sql2
GO

猜你喜欢

转载自www.cnblogs.com/JXSBoKeYuan/p/9382169.html