• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
雪飞夏日
博客园    首页    新随笔    联系   管理    订阅  订阅
通用高效分页存储过程代码
CREATE PROCEDURE pagination   @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
 通用高效分页存储过程代码 通用高效分页存储过程代码
  http://huangjt.jobui.com/blog/11027.html
  -- 获取指定页的数据
  CREATE PROCEDURE pagination
  @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
  declare @strSQL varchar(5000) -- 主语句
  declare @strTmp varchar(110) -- 临时变量
  declare @strOrder varchar(400) -- 排序类型
  if @doCount != 0
  begin
  if @strWhere !=''
  set @strSQL = 'select count(*) as Total from [' + @tblName + '] where '+@strWhere
  else
  set @strSQL = 'select count(*) as Total from [' + @tblName + ']'
  end
  --以上代码的意思是如果@doCount传递过来的不是0,就执行总数统计。以下的所有代码都是@doCount为0的情况
  else
  begin
  if @OrderType != 0
  begin
  set @strTmp = '<(select min'
  set @strOrder = ' order by [' + @fldName +'] desc'
  --如果@OrderType不是0,就执行降序,这句很重要!
  end
  else
  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
  exec (@strSQL)
  GO
posted on 2009-07-27 19:20  雪飞夏日  阅读(239)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3