SQL Server 存儲過程的經典分頁

建立表:

CREATE TABLE [TestTable] (

[ID] [int] IDENTITY (1, 1) NOT NULL ,

[FirstName] [nvarchar] (100) COLLATE Chinese_PRC_CI_AS NULL ,

[LastName] [nvarchar] (100) COLLATE Chinese_PRC_CI_AS NULL ,

[Country] [nvarchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,

[Note] [nvarchar] (2000) COLLATE Chinese_PRC_CI_AS NULL

) ON [PRIMARY]

GO

插入數據:(2萬條,用更多的數據測試會明顯一些)

SET IDENTITY_INSERT TestTable ON

declare @i int

set @i=1

while @i<=20000

begin

insert into TestTable([id], FirstName, LastName, Country,Note) values(@i, ''FirstName_XXX'',''LastName_XXX'',''Country_XXX'',''Note_XXX'')

set @i=@i+1

end

SET IDENTITY_INSERT TestTable OFF

-------------------------------------

分頁方案一:(利用Not In和SELECT TOP分頁)

語句形式:

SELECT TOP 10 *

FROM TestTable

WHERE (ID NOT IN

(SELECT TOP 20 id

FROM TestTable

ORDER BY id))

ORDER BY ID

SELECT TOP 頁大小 *

FROM TestTable

WHERE (ID NOT IN

(SELECT TOP 頁大小*頁數 id

FROM 表

ORDER BY id))

ORDER BY ID

-------------------------------------

分頁方案二:(利用ID大于多少和SELECT TOP分頁)

語句形式:

SELECT TOP 10 *

FROM TestTable

WHERE (ID >

(SELECT MAX(id)

FROM (SELECT TOP 20 id

FROM TestTable

ORDER BY id) AS T))

ORDER BY ID

SELECT TOP 頁大小 *

FROM TestTable

WHERE (ID >

(SELECT MAX(id)

FROM (SELECT TOP 頁大小*頁數 id

FROM 表

ORDER BY id) AS T))

ORDER BY ID

-------------------------------------

分頁方案三:(利用SQL的遊標存儲過程分頁)

create procedure XiaoZhengGe

@sqlstr nvarchar(4000), --查詢字符串

@currentpage int, --第N頁

@pagesize int --每頁行數

as

set nocount on

declare @P1 int, --P1是遊標的id

@rowcount int

exec sp_cursoropen @P1 output,@sqlstr,@scrollopt=1,@ccopt=1,@rowcount=@rowcount output

select ceiling(1.0*@rowcount/@pagesize) as 總頁數--,@rowcount as 總行數,@currentpage as 當前頁

set @currentpage=(@currentpage-1)*@pagesize+1

exec sp_cursorfetch @P1,16,@currentpage,@pagesize

exec sp_cursorclose @P1

set nocount off

其它的方案:如果沒有主鍵,可以用臨時表,也可以用方案三做,但是效率會低。

建議優化的時候,加上主鍵和索引,查詢效率會提高。

通過SQL 查詢分析器,顯示比較:我的結論是:

分頁方案二:(利用ID大于多少和SELECT TOP分頁)效率最高,需要拼接SQL語句

分頁方案一:(利用Not In和SELECT TOP分頁) 效率次之,需要拼接SQL語句

分頁方案三:(利用SQL的遊標存儲過程分頁) 效率最差,但是最爲通用

在實際情況中,要具體分析。

SQL Server 存儲過程的分頁
建立表: CREATE TABLE ( IDENTITY (1, 1) NOT NULL , (100) COLLATE Chinese_PRC_CI_AS NULL , (100) COLLATE Chinese_PRC_CI_AS NULL , (50) COLLATE Chinese_PRC_CI_AS NULL , (2000) COLLATE Chinese...查看完整版>>SQL Server 存儲過程的分頁
 
SQL Server 存儲過程的經典分頁
建立表: CREATE TABLE ( IDENTITY (1, 1) NOT NULL , (100) COLLATE Chinese_PRC_CI_AS NULL , (100) COLLATE Chinese_PRC_CI_AS NULL , (50) COLLATE Chinese_PRC_CI_AS NULL , (2000) COLLATE Chinese...查看完整版>>SQL Server 存儲過程的經典分頁
 
SQL Server 存儲過程的經典分頁
建立表: CREATE TABLE ( IDENTITY (1, 1) NOT NULL , (100) COLLATE Chinese_PRC_CI_AS NULL , (100) COLLATE Chinese_PRC_CI_AS NULL , (50) COLLATE Chinese_PRC_CI_AS NULL , (2000) COLLATE Chinese...查看完整版>>SQL Server 存儲過程的經典分頁
 
最簡單的SQL Server數據庫存儲過程分頁
1.只需要提供Sql語句和每頁的記錄數,頁數就可以了 2,速度超快喲,100W記錄1~3秒就分出來了 3,對于存儲過程特別好用 --//調用的方式 表 exec up_zbh_DivPageBySql 'select * from 表',10,3 存儲過程 exec up_zbh_DivPa...查看完整版>>最簡單的SQL Server數據庫存儲過程分頁
 
SQL Server 存儲過程的分頁方案比拼
建立表:CREATE TABLE ( IDENTITY (1, 1) NOT NULL , (100) COLLATE Chinese_PRC_CI_AS NULL , (100) COLLATE Chinese_PRC_CI_AS NULL , (50) COLLATE Chinese_PRC_CI_AS NULL , (2000) COLLATE Chinese_...查看完整版>>SQL Server 存儲過程的分頁方案比拼
 
SQL Server 存儲過程的分頁方案比拼
摘要:SQL Server 存儲過程的分頁方案比拼 轉自: aspx">http://blog.csdn.net/lihonggen0/archive/2004/09/14/103511.aspx 1SQL Server 存儲過程的分頁,這個問題已經討論過幾年了,很多朋友在問我,所以在...查看完整版>>SQL Server 存儲過程的分頁方案比拼
 
SQL Server 存儲過程的分頁方案比拼
1SQL Server 存儲過程的分頁,這個問題已經討論過幾年了,很多朋友在問我,所以在此發表一下我的觀點 2建立表: 3 4CREATE TABLE ( 5 IDENTITY (1, 1) NOT NULL , 6 (100) COLLATE Chinese_PRC_CI_AS NULL...查看完整版>>SQL Server 存儲過程的分頁方案比拼
 
SQL Server 存儲過程的分頁(轉)
SQL Server 存儲過程的分頁,這個問題已經討論過幾年了,很多朋友在問我,所以在此發表一下我的觀點建立表:CREATE TABLE ( IDENTITY (1, 1) NOT NULL , (100) COLLATE Chinese_PRC_CI_AS NULL , (100) COLLA...查看完整版>>SQL Server 存儲過程的分頁(轉)
 
SQL Server 存儲過程的分頁方案比拼
轉自: 1SQL Server 存儲過程的分頁,這個問題已經討論過幾年了,很多朋友在問我,所以在此發表一下我的觀點 2建立表: 3 4CREATE TABLE ( 5 IDENTITY (1, 1) NOT NULL , 6 (100) COLLATE Chinese_PRC_CI...查看完整版>>SQL Server 存儲過程的分頁方案比拼
 
 
回到王朝網路移動版首頁