欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

asp.net 數(shù)據(jù)訪問層 存儲過程分頁語句

 更新時間:2009年12月20日 02:13:45   作者:  
在asp.net 網(wǎng)頁中如果在業(yè)務(wù)邏輯層分頁在使用PagedDataSource對象,但如果數(shù)據(jù)記錄過多,使用它會嚴重的損害應(yīng)用程序的性能.
所以最好在數(shù)據(jù)訪層分頁,如果這樣就要使用存儲過程來分頁.以下是以pubs 數(shù)據(jù)庫中的employee表為例來進行數(shù)據(jù)分頁的存儲過程,你可以參考它根據(jù)實際情況來創(chuàng)建自己的存儲過程.

注:@pageindex 數(shù)據(jù)頁的索引,@dataperpage 每頁的記錄數(shù)目,@howmanyrecords 用來獲取總的記錄數(shù).
復(fù)制代碼 代碼如下:

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 函數(shù)可以給檢索來的每條記錄按照排序來編號.

接下來你就可以在asp.net 網(wǎng)頁后臺代碼中調(diào)用該存儲過程,就可以獲取想要的數(shù)據(jù).

相關(guān)文章

最新評論