简单的Sql分页方案(转)



select top 页大小 *
  from table1
  where id>
  (select max (id) from
  (select top ((页码-1)*页大小) id from table1 order by id) as T
  )
  order by id






drop procedure pagination3
go

CREATE Procedure pagination3(
@tblName varchar(255),--表名
@strGetFields varchar(1000)='*',--需要返回的列
@fldName varchar(255) ='',--排序的字段名
@PageSize int =10,-- 页尺寸(每页记录数)
@PageIndex int =1,--页码
@doCount bit =0,-- 返回记录总数, 非0值则返回记录数
@OrderType bit =0,-- 设置排序类型, 非0值则降序
@strWhere varchar(1500)='')-- 查询条件 (注意: 不要加 where)
AS
begin
declare @strSQL varchar(5000)-- 主语句
declare @strTmp varchar(1100)-- 临时变量
declare @strOrder varchar(4000)-- 排序类型


if @doCount!=0
begin
if @strWhere!=''
set @strSQL='select count(*) asTotal from ['+@tblName+'] where '+@strWhere
else set @strSQL='select count(*) as Total from ['+@tblName+']'
end --以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都是@doCount为0的情况
else
begin
if @OrderType!=0 --降序(desc)
begin
set @strTmp='<(select min'
set @strOrder='order  by['+@fldName+'] desc' --如果@OrderType不是0,就执行降序,这句很重要!
end
else --升序(asc)
begin
set @strTmp='>(select max'
set @strOrder='order by['+@fldName+'] asc'
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 top '+str(@PageSize)+' '+@strGetFields+' from ['+@tblName+'] where ['+@fldName+'] '+@strTmp+'(['+@fldName+']) from (select top'+str((@PageIndex-1)*@PageSize)+'['+@fldName+'] from ['+@tblName+']'+@strOrder+') as tblTmp)'+@strOrder
if @strWhere!=''
set @strSQL='select top '+str(@PageSize)+' '+@strGetFields+' from ['+@tblName+'] where ['+@fldName+']'+@strTmp+'(['+@fldName+']) from (select top'+str((@PageIndex-1)*@PageSize)+'['+@fldName+'] from['+@tblName+'] where'+@strWhere+''+@strOrder+') as tblTmp) and '+@strWhere+' '+@strOrder
end
end

--print ''+@strSQL
exec (@strSQL)
end
GO


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值