基于SQL Server 2005新特性的分页存储过程

本文介绍了一个SQL Server中用于实现高效分页查询的存储过程。该过程通过传入页码、页大小、排序字段等参数,实现了灵活的数据分页功能,并支持返回记录总数。此外,还提供了一个具体示例来展示如何使用此存储过程进行数据检索。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CREATE   PROCEDURE [dbo].[PagingRecord]
    ( 
    
@PageIndex int,--页号,从0开始
    @PageSize int,--页尺寸
    @OrderField varchar(100),--排序字段及类型(多个条件用逗号分开)如:JobID DESC,Checkintime
    @TableName varchar(100),--表名或视图表 
    @StrWhere varchar(2000),--条件 
    @FieldList varchar(2000),--欲选择字段列表      
    @DoCount  AS bit=1-- 0值返回记录总数, 非 0 值则返回记录
    ) 
AS 

BEGIN TRAN

DECLARE @SqlQuery varchar(4000)

IF @DoCount<>0
    
Goto GetCount
Else
    
Goto GetSearch



GetCount:
--返回记录总数
    DECLARE @SearchSql AS Nvarchar(4000)
    
SET @SearchSql= 'SELECT Count(*) AS Total FROM '+@TableName+' WHERE '+@StrWhere
    
exec sp_executesql @SearchSql
    
--print @SearchSql 
COMMIT TRAN
    
return

GetSearch:

    
SET @SqlQuery='SELECT '+@FieldList+'
    FROM (SELECT row_number() over(ORDER BY 
'+@OrderField+') as rownum, 
            
'+@FieldList+'
          FROM 
'+@TableName+' WHERE '+@StrWhere +') as temp
    WHERE rownum BETWEEN (
'+cast(@PageIndex as varchar)+'-1)*'+cast(@PageSize as varchar)+'+1 and '+cast(@PageIndex as varchar)+'*'+cast(@PageSize as varchar+ ' ORDER BY '+@OrderField
    
--print @SqlQuery
    SET NOCOUNT ON
    
execute(@SqlQuery)
    
SET NOCOUNT OFF


COMMIT TRAN

 

 

 

××××××××××××××××××××××××××××××××××××
WITH OrderedOrders AS
(SELECT *,
ROW_NUMBER() OVER (order by addtime)as RowNumber
FROM VisitLogs )
SELECT *
FROM OrderedOrders
WHERE RowNumber between 10 and 60;

××××××××××××××××××××××××××××××××××××××

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值