视频1 视频21 视频41 视频61 视频文章1 视频文章21 视频文章41 视频文章61 推荐1 推荐3 推荐5 推荐7 推荐9 推荐11 推荐13 推荐15 推荐17 推荐19 推荐21 推荐23 推荐25 推荐27 推荐29 推荐31 推荐33 推荐35 推荐37 推荐39 推荐41 推荐43 推荐45 推荐47 推荐49 关键词1 关键词101 关键词201 关键词301 关键词401 关键词501 关键词601 关键词701 关键词801 关键词901 关键词1001 关键词1101 关键词1201 关键词1301 关键词1401 关键词1501 关键词1601 关键词1701 关键词1801 关键词1901 视频扩展1 视频扩展6 视频扩展11 视频扩展16 文章1 文章201 文章401 文章601 文章801 文章1001 资讯1 资讯501 资讯1001 资讯1501 标签1 标签501 标签1001 关键词1 关键词501 关键词1001 关键词1501 专题2001
sql存储过程分页代码支持亿万庞大数据量
2020-11-09 07:11:24 责编:小采
文档


代码如下:
CREATE PROCEDURE page
@tblName varchar(255), -- 表名
@strGetFields varchar(1000) = '*', -- 需要返回的列
@fldName varchar(255)='id', -- 排序的字段名
@PageSize int = 10, -- 页尺寸
@PageIndex int = 1, -- 页码
@doCount bit = 0, -- 返回记录总数, 非 0 值则返回
@OrderType bit = 0, -- 设置排序类型, 非 0 值则降序 0:asc 1:desc
@strWhere varchar(1500) = '', -- 查询条件 (注意: 不要加 where)
@ID nvarchar(50)='id' --主表的列。最好是主键
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 + '( '+ @ID + ' ) 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 + '('
+ @ID + ') from (select top ' + str((@PageIndex-1)*@PageSize) + ' '
+ @fldName + ' from ' + @tblName + ' where ' + @strWhere + ' '
+ @strOrder + ') as tblTmp) and ' + @strWhere + ' ' + @strOrder
end
end
exec (@strSQL)

您可能感兴趣的文章:

  • 大数据量时提高分页的效率
  • 数据库高并发情况下重复值写入的避免 字段组合约束
  • 大数据量分页存储过程效率测试附测试代码与结果
  • 大数据量,海量数据处理方法总结
  • MySQL数据库优化经验详谈(服务器普通配置)
  • MySQL数据库十大优化技巧
  • SQL Server数据库的高性能优化经验总结
  • 数据库性能优化三:程序操作优化提升性能
  • 数据库性能优化二:数据库表优化提升性能
  • 数据库性能优化一:数据库自身优化提升性能
  • Oracle 数据库优化实战心得总结
  • 优化mysql数据库的经验总结
  • mysql数据库优化总结(心得)
  • 关于数据库优化问题收集汇总
  • oracle数据库sql的优化总结
  • sql 百万级数据库优化方案分享
  • 优化Mysql数据库的8个方法
  • mysql数据库sql优化原则(经验总结)
  • 针对Sqlserver大数据量插入速度慢或丢失数据的解决方法
  • MySQL数据库优化详解
  • MySQL中实现高性能高并发计数器方案(例如文章点击数)
  • 超大数据量存储常用数据库分表分库算法总结
  • sqlserver数据库优化解析(图文剖析)
  • 详解MySQL性能优化(一)
  • 详解MySQL性能优化(二)
  • 19个MySQL性能优化要点解析
  • 大数据量高并发的数据库优化详解
  • 下载本文
    显示全文
    专题