比较通用的存储过程分页 需要改进之处大家多多指点!

0 篇文章 0 订阅

 
--名称:创建分页存储过程 
--时间:2011-07-04
--作者:wuhan
alter proc proc_wuhan_getpages  --创建存储过程
@pageSize int,      --页大小
@currentPage int,     --当前页(第几页) 
@tableName nvarchar(100),   --表名
@columns  nvarchar(1000),   --字段名
@condition nvarchar(100),   --查询条件
@orderType int,      --排序类型(0为升序,1为降序)
@orderColumn nvarchar(100),   --排序字段
@premaryKeyColumn nvarchar(100)  --主键字段名称
as
begin
 declare @strSqlStatement nvarchar(2000)   --存储过程最后执行的语句
 declare @chartype nvarchar(10)
 begin
  if @condition=''       --查询条件为空  
  begin
   if @orderType=0       --升序
   begin
    set @chartype=' asc'
    set @strSqlStatement = 'select top ' +ltrim(@pageSize) +' '+@columns +' from ' + @tableName+ ' where ('
       + @premaryKeyColumn+' not in (select Top '+ convert(char,@pageSize *(@currentPage-1))+ @premaryKeyColumn
       + ' from '+ @tableName + ' order by ' +@orderColumn + @chartype  +')) order by ' +@orderColumn+ @chartype
   end
   else if @orderType=1
   begin
    set @chartype=' desc'    --降序
    set @strSqlStatement = 'select top ' +ltrim(@pageSize) +' '+@columns +' from ' + @tableName+ ' where ('
       + @premaryKeyColumn+' not in (select Top '+ convert(char,@pageSize *(@currentPage-1))+ @premaryKeyColumn
       + ' from '+ @tableName + ' order by ' +@orderColumn + @chartype  +')) order by ' +@orderColumn+ @chartype
   end
   print @strSqlStatement
   exec (@strSqlStatement)     --输出最后要执行的语句
  end
  else if @condition!=''        --查询条件不为空
   begin
    if @orderType=0       --升序
    begin
     set @chartype=' asc'
     set @strSqlStatement = 'select top ' +ltrim(@pageSize) +' '+@columns +' from ' + @tableName+ ' where ('
        + @premaryKeyColumn+' not in (select Top '+ convert(char,@pageSize *(@currentPage-1))+ @premaryKeyColumn
        + ' from '+ @tableName + ' order by ' +@orderColumn + @chartype  +')and '+ @condition +') order by ' +@orderColumn+ @chartype
    end
    else if @orderType=1     
    begin
     set @chartype=' desc'    --降序
     set @strSqlStatement = 'select top ' +ltrim(@pageSize) +' '+@columns +' from ' + @tableName+ ' where ('
        + @premaryKeyColumn+' not in (select Top '+ convert(char,@pageSize *(@currentPage-1))+ @premaryKeyColumn
        + ' from '+ @tableName + ' order by ' +@orderColumn + @chartype  +')and '+ @condition +')order by ' +@orderColumn+ @chartype
    end
    print @strSqlStatement
    exec (@strSqlStatement)     --输出最后要执行的语句
   end
  else
   print '出错了吧,还是要多多练习的!'+ ltrim(@pageSize)
 end
end

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值