SQL SERVER 2005分页存储过程
来源:互联网 发布:美食杰网站seo分析 编辑:程序博客网 时间:2024/05/01 21:33
/****** 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
- SQL Server 2005 存储过程分页
- MS SQL Server 2005 分页存储过程
- MS SQL Server 2005 分页存储过程
- SQL SERVER 2005分页存储过程
- SQL Server 2005分页存储过程
- SQL SERVER 2005 ROW_NUMBER() 分页存储过程
- SQL Server 2005 分页存储过程
- SQL Server 2005 分页存储过程
- SQL Server 2005分页存储过程
- SQL SERVER 2005分页存储过程
- SQL Server 2005 分页存储过程 row_number()
- SQL SERVER 2005分页存储过程
- 通用分页存储过程(SQL Server 2005)
- SQL Server 2005高效分页存储过程
- SQL Server 2005分页存储过程
- SQL Server 分页存储过程
- 分页存储过程(SQL Server)
- SQL Server 分页存储过程
- VC++的GDI绘图函数:SetROP2 橡皮筋绘图技术中的应用
- 计算机 控制与信息技术重要期刊网址
- 用c++写银行家算法的感想
- SAP的架构
- Nandflash K9F1208U0B学习
- SQL SERVER 2005分页存储过程
- malformed URI sequence
- 使用gl函数要先创建context
- Summary the high availability technologies offered by SQL Server 2008.
- [转]C#cookie操作类
- bootloader
- 关于MRP的几个概念
- Linux5 上Oracle 10g客户端的安装和配置
- Watts Humphrey ---CMM之父 故去