建立好如下的存儲過程,以后要分頁,直接調用改存儲過程就可以了。
注意:數(shù)據(jù)量大、性能要求高的,請個性化處理。
復制代碼 代碼如下:
ALTER PROCEDURE [dbo].[COMMON_PROCEDURE_SelectWithPage]
@Sql VARCHAR(5000),
@CurrentPageNo INT,
@PageSize INT,
@TotalNum INT OUTPUT
AS
SET NOCOUNT ON
DECLARE @SqlCmd VARCHAR(5000)
------------------------------------------ --查詢數(shù)據(jù)
SET @SqlCmd = 'SELECT * FROM (' + @Sql + ') A WHERE RowIndex BETWEEN ' + CONVERT(VARCHAR,(@CurrentPageNo-1) * @PageSize + 1) + ' AND ' + CONVERT(VARCHAR,@CurrentPageNo * @PageSize)
EXEC(@SqlCmd) PRINT (@SqlCmd)
------------------------------------------ --求記錄總數(shù)
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分頁的實現(xiàn)方法
- Oracle row_number() over()解析函數(shù)高效實現(xiàn)分頁
- C#拼接SQL語句 用ROW_NUMBER實現(xiàn)的高效分頁排序
- SQL2005利用ROW_NUMBER() OVER實現(xiàn)分頁功能
- 高效的SQLSERVER分頁查詢(推薦)
- 解析數(shù)據(jù)庫分頁的兩種方法對比(row_number()over()和top的對比)
- 使用row_number()實現(xiàn)分頁實例
- SQLSERVER分頁查詢關于使用Top方式和row_number()解析函數(shù)的不同
- SQL Server使用row_number分頁的實現(xiàn)方法