SQL SERVER 2005分页存储过程

本文介绍了一个 SQL 存储过程,用于实现通用的分页数据查询功能。该存储过程支持自定义字段选择、表源、搜索条件及排序方式等参数,能够灵活地应用于不同的分页需求场景。

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

/* ***** Object:  StoredProcedure [dbo].[Inovout_GetRecordFromPage]    Script Date: 05/28/2007 15:12:11 ***** */
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
--   =============================================
--  Author:        Ristona
--  Create date:  2007 - 5 - 28
--  Description:    支持分页数据查询
--   =============================================
CREATE PROCEDURE [dbo].[GetRecordFromPage] 
    @SelectList            VARCHAR(
2000 ),     -- 欲选择字段列表
    @TableSource        VARCHAR(
100 ),     -- 表名或视图表 
    @SearchCondition    VARCHAR(
2000 ),     -- 查询条件
    @OrderExpression    VARCHAR(
1000 ),     -- 排序表达式
    @PageIndex            INT 
=   1 ,         -- 页号,从0开始
    @PageSize            INT 
=   10          -- 页尺寸
AS 
BEGIN
    IF @SelectList IS NULL OR LTRIM(RTRIM(@SelectList)) 
=   ''
    BEGIN
        SET @SelectList 
=   ' * '
    END
    PRINT @SelectList
    
    SET @SearchCondition 
=  ISNULL(@SearchCondition, '' )
    SET @SearchCondition 
=  LTRIM(RTRIM(@SearchCondition))
    IF @SearchCondition 
<>   ''
    BEGIN
        IF UPPER(SUBSTRING(@SearchCondition,
1 , 5 ))  <>   ' WHERE '
        BEGIN
            SET @SearchCondition 
=   ' WHERE  '   +  @SearchCondition
        END
    END
    PRINT @SearchCondition

    SET @OrderExpression 
=  ISNULL(@OrderExpression, '' )
    SET @OrderExpression 
=  LTRIM(RTRIM(@OrderExpression))
    IF @OrderExpression 
<>   ''
    BEGIN
        IF UPPER(SUBSTRING(@OrderExpression,
1 , 5 ))  <>   ' WHERE '
        BEGIN
            SET @OrderExpression 
=   ' ORDER BY  '   +  @OrderExpression
        END
    END
    PRINT @OrderExpression

    IF @PageIndex IS NULL OR @PageIndex 
<   1
    BEGIN
        SET @PageIndex 
=   1
    END
    PRINT @PageIndex
    IF @PageSize IS NULL OR @PageSize 
<   1
    BEGIN
        SET @PageSize 
=   10
    END
    PRINT  @PageSize

    DECLARE @SqlQuery VARCHAR(
4000 )

    SET @SqlQuery
= ' SELECT  ' + @SelectList + ' ,RowNumber 
    FROM 
        (SELECT 
'  + @SelectList +  ' ,ROW_NUMBER() OVER(  ' + @OrderExpression + ' ) AS RowNumber 
          FROM 
' +@TableSource+ '   ' + @SearchCondition + ' ) AS RowNumberTableSource 
    WHERE RowNumber BETWEEN 
'  + CAST(((@PageIndex - 1)* @PageSize+1) AS VARCHAR) 
     +   '  AND  '   +  
    CAST((@PageIndex 
*  @PageSize) AS VARCHAR) 
--     ORDER BY  '  + @OrderExpression
    PRINT @SqlQuery
    SET NOCOUNT ON
    EXECUTE(@SqlQuery)
    SET NOCOUNT OFF
 
    RETURN @@RowCount
END
GO

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值