所以最好在資料訪層分頁,如果這樣就要使用預存程序來分頁.以下是以pubs 資料庫中的employee表為例來進行資料分頁的預存程序,你可以參考它根據實際情況來建立自己的預存程序.
注:@pageindex 資料頁的索引,@dataperpage 每頁的記錄數目,@howmanyrecords 用來擷取總的記錄數. 複製代碼 代碼如下:create proc getdata @pageindex int,@dataperpage int,@howmanyrecords int output
as
declare @temptable table
(
rowindex int,
emp_id char(9),
fname varchar(20),
minit char(1),
lname varchar(30)
)
insert into @temptable
select row_number() over(order by emp_id) as rowindex,emp_id,fname,minit,lname
from employee
select @howmanyrecords=count(rowindex) from @temptable
select * from @temptable
where rowindex>(@pageindex-1)*@dataperpage
and rowindex<=@pageindex*@dataperpage
declare @howmanyrecords int
exec getdata 2,5,@howmanyrecords output
select @howmanyrecords
declare @x int, @y int, @z int
select @x = 1, @y = 2, @z=3
select @x,@y,@z
create proc getdata2 @pageindex int,@dataperpage int,@howmanyrecords int output
as
declare @temptable table
(
rowindex int,
emp_id char(9),
fname varchar(20),
minit char(1),
lname varchar(30)
)
insert into @temptable
select row_number() over(order by emp_id) as rowindex,emp_id,fname,minit,lname
from employee
select @howmanyrecords=count(rowindex) from @temptable
select * from @temptable
where rowindex>(@pageindex-1)*@dataperpage
and rowindex<=@pageindex*@dataperpage
其中Row_number 函數可以給檢索來的每條記錄按照排序來編號.
接下來你就可以在asp.net 網頁後台代碼中調用該預存程序,就可以擷取想要的資料.