主页 > 知识库 > 一个基于ROW_NUMBER()的通用分页存储过程代码

一个基于ROW_NUMBER()的通用分页存储过程代码

热门标签:数字匠心电销机器人 没听见电话机器人帮你接 al智能电话机器人 成都电话外呼系统一般多少钱 最新人工智能电销机器人 如何做地图标注图铺 银川高频外呼回拨系统多少钱 陕西电销外呼系统好用吗 兰州语音外呼系统运营商
建立好如下的存储过程,以后要分页,直接调用改存储过程就可以了。
注意:数据量大、性能要求高的,请个性化处理。
复制代码 代码如下:

ALTER PROCEDURE [dbo].[COMMON_PROCEDURE_SelectWithPage]
@Sql VARCHAR(5000),
@CurrentPageNo INT,
@PageSize INT,
@TotalNum INT OUTPUT
AS
SET NOCOUNT ON
DECLARE @SqlCmd VARCHAR(5000)
------------------------------------------ --查询数据
SET @SqlCmd = 'SELECT * FROM (' + @Sql + ') A WHERE RowIndex BETWEEN ' + CONVERT(VARCHAR,(@CurrentPageNo-1) * @PageSize + 1) + ' AND ' + CONVERT(VARCHAR,@CurrentPageNo * @PageSize)
EXEC(@SqlCmd) PRINT (@SqlCmd)
------------------------------------------ --求记录总数
IF @TotalNum = -1
BEGIN
CREATE TABLE #Temp1(num INT)
INSERT INTO #Temp1
EXEC('SELECT count(*) FROM (' + @Sql + ') A')
SELECT @TotalNum=(SELECT * FROM #Temp1)
DROP TABLE #Temp1
END

用法很简单,但必须在传入的SQL中使用ROW_NUMBER() OVER(...) AS RowIndex :
DECLARE @Sql VARCHAR(5000)
DECLARE @CurrentPageNo INT
DECLARE @PageSize INT
DECLARE @TotalNum INT

SET @CurrentPageNo = 100
SET @PageSize = 10
SET @TotalNum = -1
SET @Sql = ' SELECT *, ROW_NUMBER() OVER (ORDER BY 排序字段) AS RowIndex FROM 表名 A WITH (NOLOCK) '

EXEC [dbo].[COMMON_PROCEDURE_SelectWithPage] @Sql,@CurrentPageNo,@PageSize,@TotalNum OUTPUT

SELECT @TotalNum
您可能感兴趣的文章:
  • sqlserver 通用存储过程分页代码(附使用ROW_NUMBER()和不使用ROW_NUMBER()两种情况性能分析)
  • sqlserver2005使用row_number() over分页的实现方法
  • Oracle row_number() over()解析函数高效实现分页
  • C#拼接SQL语句 用ROW_NUMBER实现的高效分页排序
  • SQL2005利用ROW_NUMBER() OVER实现分页功能
  • 高效的SQLSERVER分页查询(推荐)
  • 解析数据库分页的两种方法对比(row_number()over()和top的对比)
  • 使用row_number()实现分页实例
  • SQLSERVER分页查询关于使用Top方式和row_number()解析函数的不同
  • SQL Server使用row_number分页的实现方法

标签:朔州 本溪 通化 邢台 巴彦淖尔 宜春 盐城 辽源

巨人网络通讯声明:本文标题《一个基于ROW_NUMBER()的通用分页存储过程代码》,本文关键词  一个,基于,ROW,NUMBER,的,通用,;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 下面列出与本文章《一个基于ROW_NUMBER()的通用分页存储过程代码》相关的同类信息!
  • 本页收集关于一个基于ROW_NUMBER()的通用分页存储过程代码的相关信息资讯供网民参考!
  • 推荐文章