亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

[數(shù)據(jù)庫] 通用分頁存儲(chǔ)過程第5/5頁

 更新時(shí)間:2007年02月09日 00:00:00   作者:  

以下這個(gè)是我自己寫的一個(gè)分頁通用存儲(chǔ)過程

該方法也就是上頭所提到的行計(jì)數(shù)的方式,在系統(tǒng)中使用發(fā)現(xiàn)過很多次問題,這是最終版本應(yīng)該不會(huì)再有什么算法之類的問題出現(xiàn)了

這個(gè)存儲(chǔ)過程的原理就是“譬如現(xiàn)在要第5頁數(shù)據(jù),每頁是16行,那么現(xiàn)在要的數(shù)據(jù)就是在前80行,并且不在原來的64行內(nèi)的”
復(fù)制代碼 代碼如下:

Create  Proc proc_PageRecordset 
@queryStr nvarchar(2000),  --查詢語句,用來獲取要顯示的數(shù)據(jù)必須滿足的要求@keyField nvarchar (72), --主鍵 
@pageSize int,  --每頁的行數(shù)@pageNumber int, --第幾頁 
@filter varChar(2000)='', --過濾,where后頭的語句 
@order varChar(200)='' --排序方式AS 
BEGIN 
DECLARE @sqlText AS nvarchar(4000) 
DECLARE @sqlTable AS nvarchar(4000) 
DECLARE @sqlText_PageCount  AS nvarchar(4000) 

set @filter=replace(@filter,'#','''') 

--這是最后一次所發(fā)現(xiàn)的bug,因?yàn)樵谂判蛑斜仨毚_定一個(gè)排出來的位置一樣的table,不能讓a在這次排第2,那次又排第5 
if CharIndex(@keyField,@order)=0 
Begin 
Set @order=@order+','+@keyField 
End 

if (Rtrim(@filter)='') 
begin 
SET @sqlTable = 'SELECT TOP ' + CAST((@pageNumber + 1) * @pageSize AS varchar(30)) + ' ' + @queryStr + ' ' + @order 
SET @sqlText_PageCount = 'Select Count(*) from (select ' +@queryStr+ ' ) as Table_temp' 
end 
else 
begin 
SET @sqlTable = 'SELECT TOP ' + CAST((@pageNumber + 1) * @pageSize AS varchar(30)) + ' ' + @queryStr + ' and ' + @filter + @order 
SET @sqlText_PageCount = 'Select Count(*) AS MyCount from (select ' +@queryStr+ ' and ' + @filter +' ) as Table_temp' 
end 
--譬如現(xiàn)在要第5頁數(shù)據(jù),每頁是16行,那么現(xiàn)在要的數(shù)據(jù)就是在前80行,并且不在原來的64行內(nèi)的 
SET @sqlText = 
'SELECT TOP ' + CAST(@pageSize AS varchar(30)) + ' * ' +  
'FROM (' + @sqlTable + ') AS tableA ' + 
'WHERE ' + @keyField + ' NOT IN(SELECT TOP ' + 
CAST(@pageNumber * @pageSize AS varchar(30)) + ' ' + @keyField +  
' FROM (' + @sqlTable + ') AS tableB)' 

EXEC (@sqlText) 

exec (@sqlText_PageCount) 

END 

GO

相關(guān)文章

最新評(píng)論