拋棄以往分頁方式,改用ROW_NUMBER()加BETWEEN方式的分頁儲存過程,特此分享
/**********************************************************************************************
********************通過指定的條件分頁查詢資料表【TableName
or
ViewName】記錄******************
**********************************************************************************************/
IF
EXISTS (SELECT * FROM dbo.sysobjects WHERE id = object_id
(N'[dbo].[SjjPagination]') AND OBJECTPROPERTY(id, N'IsProcedure') = 1)
DROP
PROCEDURE [dbo].[SjjPagination]
GO
SET ANSI_NULLS ON
GO
SET QUOTED_IDENTIFIER ON
GO
--引數說明
-------------------------------------------------------------
/*
*
@tblName ----要顯示的表或多個表的連線
* @fldName ----要查詢出的欄位列表,*表示全部欄位
*
@pageSize ----每頁顯示的記錄個數
* @pageIndex ----要顯示那一頁的記錄
*
@fldSort ----排序欄位列表或條件,如:id desc (多個id desc,dt asc)
*
@strCondition ----查詢條件,不需where
* @pageCount ----查詢結果分頁後的總頁數
*
@RecordCount ----查詢到的總記錄數
* @UsedTime ----耗時測試時間差
*
@strSql ----最後返回的SQL語句
*/
CREATE PROCEDURE
[dbo].[SjjPagination]
(
@tblName NVARCHAR(MAX),
@fldName
NVARCHAR(MAX),
@pageSize INT,
@pageIndex INT,
@fldSort
NVARCHAR(MAX),
@strCondition NVARCHAR(MAX),
@pageCount INT
OUTPUT,
@RecordCount INT OUTPUT,
@UsedTime INT OUTPUT,
@strSql
nvarchar(max) = '' OUTPUT
)
AS
SET NOCOUNT ON
DECLARE @startRow
int, @endRow INT ----用於存放起始值與結束值
DECLARE @timediff
DATETIME ----用於存放時間差值
DECLARE @SqlCounts
NVARCHAR(MAX) ----用於存放總記錄數查詢語句
DECLARE @strTmp
NVARCHAR(MAX) ----用於存放查詢語句
DECLARE @strWhere
NVARCHAR(MAX) ----用於存放查詢條件
SELECT @timediff =
getdate() ----設定開始時間
SET @startRow = (@pageIndex - 1) * @pageSize +
1 ----設定起始值
SET @endRow = @startRow + @pageSize -
1 ----設定結束值
----設定總記錄數查詢語句----
IF @strCondition is null or
@strCondition='' ----沒有設定查詢條件
BEGIN
SET @SqlCounts = 'SELECT
@RecordCount = COUNT(*) FROM ' +
@tblName
END
ELSE ----有設定查詢條件
BEGIN
SET @strWhere = ' WHERE
' + @strCondition
SET @SqlCounts = 'SELECT @RecordCount = COUNT(*) FROM '
+ @tblName + @strWhere
END
----取得查詢結果總數量-----
exec sp_executesql
@SqlCounts,N'@RecordCount int out ',@RecordCount out
declare @tmpCounts int
if @RecordCount = 0
set @tmpCounts = 1
else
set @tmpCounts
= @RecordCount
----取得分頁總數 ----
set
@pageCount=(@tmpCounts+@pageSize-1)/@pageSize
----開始分頁計算並取出相應資料----
----SELECT
* FROM (SELECT *,ROW_NUMBER() OVER (ORDER BY contnet_keyword_addDate DESC) AS
RowNumber FROM Public_content_keyword ) T WHERE T.RowNumber BETWEEN @startRow
AND @endRow
IF @pageIndex = 1
BEGIN
IF @strCondition is null or
@strCondition='' ----沒有設定顯示條件
BEGIN
SET @strTmp = 'SELECT TOP ' +
CAST(@pageSize as VARCHAR(max)) + ' ' + @fldName + ' FROM ' +
@tblName
END
ELSE ----有設定查詢條件
BEGIN
SET @strTmp =
'SELECT TOP ' + CAST(@pageSize as VARCHAR(max)) + ' ' + @fldName + ' FROM ' +
@tblName + @strWhere
END
END
ELSE
BEGIN
IF
@strCondition is null or @strCondition='' ----沒有設定顯示條件
BEGIN
SET
@strTmp = 'SELECT ' + @fldName + ' FROM (SELECT ' + @fldName + ',ROW_NUMBER()
OVER (ORDER BY ' + @fldSort + ') AS RowNumber FROM '+ @tblName +') T WHERE
T.RowNumber BETWEEN ' + CAST(@startRow as VARCHAR(max)) + ' AND ' + CAST(@endRow
as VARCHAR(max))
END
ELSE ----有設定查詢條件
BEGIN
SET
@strTmp = 'SELECT ' + @fldName + ' FROM (SELECT ' + @fldName + ',ROW_NUMBER()
OVER (ORDER BY ' + @fldSort + ') AS RowNumber FROM '+ @tblName + @strWhere +') T
WHERE T.RowNumber BETWEEN ' + CAST(@startRow as VARCHAR(max)) + ' AND ' +
CAST(@endRow as VARCHAR(max))
END
END
------返回查詢結果-----
SET
@strSql = @strTmp
EXEC(@strTmp)
SET @UsedTime =
DATEDIFF(ms,@timediff,GETDATE())
SET NOCOUNT OFF
GO
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/16436858/viewspace-616724/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- SQL 分頁儲存過程SQL儲存過程
- SqlServer-儲存過程分頁SQLServer儲存過程
- Oracle 儲存過程分頁 + Sqlsugar呼叫Oracle儲存過程SqlSugar
- Sql儲存過程分頁--臨時表儲存SQL儲存過程
- MyBatis實現分頁的方式MyBatis
- Java中Elasticsearch 實現分頁方式(三種方式)JavaElasticsearch
- MyBatis(八) 資料庫BLOB讀寫、批量更新操作、儲存過程呼叫、分表、分頁MyBatis資料庫儲存過程
- Oracle服務啟動-索引-子查詢-分頁儲存過程問題Oracle索引儲存過程
- Springboot呼叫Oracle儲存過程的幾種方式Spring BootOracle儲存過程
- Spring boot方式使用MyBatis-Plus分頁操作Spring BootMyBatis
- 計算機作業系統(虛擬儲存器篇含分頁儲存管理方式與頁面置換演算法等)OperatingSystem-VirtualMemory計算機作業系統演算法
- SSH整合實現分頁查詢(兩種方式)
- 分頁實現前五後五ajax區域性重新整理方式分頁實現
- SqlServer儲存過程應用二:分頁查詢資料並動態拼接where條件SQLServer儲存過程
- 加鹽hash儲存密碼的正確方式密碼
- 盤點現在用的SqlServer 5種分頁方式和拉姆達表示式分頁,進來看看吧。SQLServer
- 分頁元件原始碼分享元件原始碼
- 線上直播原始碼,java資料分頁幾種方式原始碼Java
- 直播軟體原始碼,java資料分頁幾種方式原始碼Java
- 398、Java框架52 -【Hibernate - 分頁、兩種獲取方式】 2020.10.27Java框架
- mysql分頁-limit offset分頁MySqlMIT
- 基於Sql server資料庫的四種分頁方式總結SQLServer資料庫
- mssql 儲存過程呼叫另一個儲存過程中的結果的方法分享SQL儲存過程
- keep-alive + vuex + mint + Infinite scroll 儲存分頁列表資料Keep-AliveVue
- 拋棄UITableView,讓所有列表頁不再難構建UIView
- Laravel 使用 layui 分頁過長LaravelUI
- flask 分頁 | 翻頁Flask
- Django的分頁Django
- ElasticSearch - 分頁查詢方式二 【scroll】滾動查詢(kibana、Java示例)ElasticsearchJava
- 是時候拋棄傳統ERP系統,改用SaaS了!
- mysql分頁時offset過大的Sql最佳化經驗分享MySql
- php 分頁 分頁類 簡單實用PHP
- 日期的正確儲存方式
- 分頁器
- Flask——分頁Flask
- 集合分頁
- php 分頁PHP
- 分頁案例
- 段頁式儲存