mssql 高效的分页存储过程分享
更新时间:2013年03月14日 23:18:30 作者:
废话不多说,直接上结果,相信这也是大多数搜索答案的人最愿意看的方式。
最近在做一个几百万条数据的分页查询,研究了各种方案,在本机上用项目的实际数据库做测试,测试过程 is very 痛苦,不堪回首ing。现在废话不多说,直接上结果,相信这也是大多数搜索答案的人最愿意看的方式。
以下是存储过程的代码:
复制代码 代码如下:
CREATE PROCEDURE [dbo].[P_GridViewPager] (
@recordTotal INT OUTPUT, --输出记录总数
@viewName VARCHAR(800), --表名
@fieldName VARCHAR(800) = '*', --查询字段
@keyName VARCHAR(200) = 'Id', --索引字段
@pageSize INT = 20, --每页记录数
@pageNo INT =1, --当前页
@orderString VARCHAR(200), --排序条件
@whereString VARCHAR(800) = '1=1' --WHERE条件
)
AS
BEGIN
DECLARE @beginRow INT
DECLARE @endRow INT
DECLARE @tempLimit VARCHAR(200)
DECLARE @tempCount NVARCHAR(1000)
DECLARE @tempMain VARCHAR(1000)
--declare @timediff datetime
set nocount on
--select @timediff=getdate() --记录时间
SET @beginRow = (@pageNo - 1) * @pageSize + 1
SET @endRow = @pageNo * @pageSize
SET @tempLimit = 'rows BETWEEN ' + CAST(@beginRow AS VARCHAR) +' AND '+CAST(@endRow AS VARCHAR)
--输出参数为总记录数
SET @tempCount = 'SELECT @recordTotal = COUNT(*) FROM (SELECT '+@keyName+' FROM '+@viewName+' WHERE '+@whereString+') AS my_temp'
EXECUTE sp_executesql @tempCount,N'@recordTotal INT OUTPUT',@recordTotal OUTPUT
--主查询返回结果集
SET @tempMain = 'SELECT * FROM (SELECT ROW_NUMBER() OVER (order by '+@orderString+') AS rows ,'+@fieldName+' FROM '+@viewName+' WHERE '+@whereString+') AS main_temp WHERE '+@tempLimit
--PRINT @tempMain
EXECUTE (@tempMain)
--select datediff(ms,@timediff,getdate()) as 耗时
set nocount off
END
GO
相关文章
SQL Server2019安装的详细步骤实战记录(亲测可用)
SQL Server 2019作为编程人员必须使用到的一款数据库管理软件,许多初学者在安装这款软件的时候都出现了各种各样的问题,下面这篇文章主要给大家介绍了关于SQL Server2019安装的详细步骤,需要的朋友可以参考下2022-06-06SQLserver存储过程写法与设置定时执行存储过程方法详解
一直都很想了解如何写存储过程,对于不熟悉的东西,总是觉得很神秘,下面这篇文章主要给大家介绍了关于SQLserver存储过程写法与设置定时执行存储过程方法的相关资料,需要的朋友可以参考下2023-03-03Windows Server2008 R2 MVC 环境安装配置教程
这篇文章主要为大家详细介绍了Windows Server2008 R2 MVC 环境安装配置教程,感兴趣的小伙伴们可以参考一下2016-09-09在SQL Server数据库中为标识(IDENTITY)列插入显式值
SQL Server中的标识列和ACCESS中的“自动编号”相似,都是插入记录的时候自动生成,一般不允许也不需要我们去手动修改它2007-02-02巧妙利用PARTITION分组排名递增特性解决合并连续相同数据行
这篇文章主要介绍了巧妙利用PARTITION分组排名递增特性解决合并连续相同数据行,需要的朋友可以参考下2014-08-08
最新评论