小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

SQL Server中利用存儲過程來高性能地進(jìn)行分頁

 小朋 2006-10-16
分頁查詢的方法已經(jīng)很多很多,在這里我也加入成為其中一員。
      SQL Server中有一個Set Rowcount的的設(shè)置,它的意思是使命令的處理在響應(yīng)指定的行數(shù)之后停止處理命令,利用這個特點,我們可以借用它來在一個千萬行級數(shù)據(jù)表中實現(xiàn)高性能分頁查詢。先來說說實現(xiàn)方式:
      1、我們來假定Table中有一個已經(jīng)建立了索引的主鍵字段ID(整數(shù)型),我們將按照這個字段來取數(shù)據(jù)進(jìn)行分頁。
      2、頁的大小我們放在@PageSize中
      3、當(dāng)前頁號我們放在@CurrentPage中
      4、如何讓記錄指針快速滾動到我們要取的數(shù)據(jù)開頭的那一行呢,這是關(guān)鍵所在!有了Set RowCount,我們就很容易實現(xiàn)了。
      5、如果我們成功地滾動記錄指針到我們要取的數(shù)據(jù)的開頭的那一行,然后我們把那一行的記錄的ID字段的值記錄下來,那么,利用Top和條件,我們就很容易的得到指定頁的數(shù)據(jù)了。當(dāng)然,有了Set RowCount,我們難道還用Top么?
      看看Set Rowcount怎么來幫我們的忙吧:

Declare @ID int
Declare @MoveRecords int

--@CurrentPage和@PageSize是傳入?yún)?shù)
Set @MoveRecords=@CurrentPage * @PageSize+1

--下面兩行實現(xiàn)快速滾動到我們要取的數(shù)據(jù)的行,并把ID記錄下來
Set Rowcount @MoveRecords
Select @ID=ID from Table1 Order by ID

Set Rowcount @PageSize
--最恨為了減少麻煩使用*了,但是在這里為了說明方便,暫時用一下
Select * From Table1 Where ID>=@ID Order By ID
Set Rowcount 0


      大家可以試試看,在一個1千W記錄的表里面,一下子方翻頁到第100頁(每頁100條),看看有多快!

http://name-lh.cnblogs.com/archive/2006/03/08/346059.html
 

    本站是提供個人知識管理的網(wǎng)絡(luò)存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評論

    發(fā)表

    請遵守用戶 評論公約

    類似文章 更多