資料庫分頁顯示

2021-10-07 17:49:57 字數 4771 閱讀 5289

用的sql server 2012版本。下面都用pageindex表示頁數,pagesize表示一頁包含的記錄。並且下面涉及到具體例子的,設定查詢第2頁,每頁含10條記錄。

首先說一下sql server的分頁與mysql的分頁的不同,mysql的分頁直接是用limit (pageindex-1),pagesize就可以完成,但是sql server 並沒有limit關鍵字,只有類似limit的top關鍵字。所以分頁起來比較麻煩。

sql server分頁我所知道的就只有四種:三重迴圈;利用max(主鍵);利用row_number關鍵字,offset/fetch next關鍵字(是通過蒐集網上的其他人的方法總結的,應該目前只有這四種方法的思路,其他方法都是基於此變形的)。

要查詢的學生表的部分記錄

推薦第四種方法:offset /fetch next(2012版本及以上才有)

**實現

set statistics time on;

-- 分頁查詢(通用型)

select * from student

order by sno 

offset ((@pageindex-1)*@pagesize) rows

fetch next @pagesize rows only;

-- 分頁查詢第2頁,每頁有10條記錄

select * from student

order by sno  

offset 10 rows

fetch next 10 rows only ;

offset a rows ,將前a條記錄捨去,fetch next b rows only ,向後在讀取b條資料。

效率最差:方法一:三重迴圈

思路先取前20頁,然後倒序,取倒序後前10條記錄,這樣就能得到分頁所需要的資料,不過順序反了,之後可以將再倒序回來,也可以不再排序了,直接交給前端排序。

還有一種方法也算是屬於這種型別的,這裡就不放**出來了,只講一下思路,就是先查詢出前10條記錄,然後用not in排除了這10條,再查詢。

**實現

-- 設定執行時間開始,用來檢視效能的

set statistics time on ;

-- 分頁查詢(通用型)

select * 

from (select top pagesize * 

from (select top (pageindex*pagesize) * 

from student 

order by sno asc ) -- 其中裡面這層,必須指定按照公升序排序,省略的話,查詢出的結果是錯誤的。

as temp_sum_student 

order by sno desc ) temp_order

order by sno asc

-- 分頁查詢第2頁,每頁有10條記錄

select * 

from (select top 10 * 

from (select top 20 * 

from student 

order by sno asc ) -- 其中裡面這層,必須指定按照公升序排序,省略的話,查詢出的結果是錯誤的。

as temp_sum_student 

order by sno desc ) temp_order

order by sno asc

;查詢出的結果及時間

方法二:利用max(主鍵)

先top前11條行記錄,然後利用max(id)得到最大的id,之後再重新再這個表查詢前10條,不過要加上條件,where id>max(id)。

**實現

set statistics time on;

-- 分頁查詢(通用型)

select top pagesize * 

from student 

where sno>=

(select max(sno) 

from (select top ((pageindex-1)*pagesize+1) sno

from student 

order by  sno asc) temp_max_ids) 

order by sno;

-- 分頁查詢第2頁,每頁有10條記錄

select top 10 * 

from student 

where sno>=

(select max(sno) 

from (select top 11 sno

from student 

order by  sno asc) temp_max_ids) 

order by sno;

查詢出的結果及時間

方法三:利用row_number關鍵字

直接利用row_number() over(order by id)函式計算出行數,選定相應行數返回即可,不過該關鍵字只有在sql server 2005版本以上才有。

sql實現

set statistics time on;

-- 分頁查詢(通用型)

select top pagesize * 

from (select row_number() 

over(order by sno asc) as rownumber,* 

from student) temp_row

where rownumber>((pageindex-1)*pagesize);

set statistics time on;

-- 分頁查詢第2頁,每頁有10條記錄

select top 10 * 

from (select row_number() 

over(order by sno asc) as rownumber,* 

from student) temp_row

where rownumber>10;

第四種方法:offset /fetch next(2012版本及以上才有)

**實現

set statistics time on;

-- 分頁查詢(通用型)

select * from student

order by sno 

offset ((@pageindex-1)*@pagesize) rows

fetch next @pagesize rows only;

-- 分頁查詢第2頁,每頁有10條記錄

select * from student

order by sno  

offset 10 rows

fetch next 10 rows only ;

offset a rows ,將前a條記錄捨去,fetch next b rows only ,向後在讀取b條資料。

封裝的儲存過程

最後,我封裝了乙個分頁的儲存過程,方便大家呼叫,這樣到時候寫分頁的時候,直接呼叫這個儲存過程就可以了。

分頁的儲存過程

create procedure paging_procedure

(    @pageindex int, -- 第幾頁

@pagesize int  -- 每頁包含的記錄數)as

begin 

select top (select @pagesize) *     -- 這裡注意一下,不能直接把變數放在這裡,要用select

from (select row_number() over(order by sno) as rownumber,* 

from student) temp_row 

where rownumber>(@pageindex-1)*@pagesize;

end-- 到時候直接呼叫就可以了,執行如下的語句進行呼叫分頁的儲存過程

exec paging_procedure @pageindex=2,@pagesize=10;

總結根據以上四種分頁的方法執行的時間可以知道,以上四種分頁方法中,第二,第三,第三四種方法效能是差不多的,但是第一種效能很差,不推薦使用。還有就是這篇部落格這是測試了小量資料,還沒有分頁大量資料,所以不清楚在大量資料要分頁時哪種方法的效能更加好。我這裡推薦第四種,畢竟第四種是sql server公司公升級後推出的新方法,所以應該理論上效能和可讀性都會更加好。

一、使用rownum分頁顯示方式

方式1:

select *

from (select rownum r, a.* from b$i_exch_info a where rownum <= 10)

where r >= 5;

方式2:

select *

from (select rownum r, a.* from b$i_exch_info a)

where r between 5 and 10;

方式3: 

select * from b$i_exch_info where rownum <= 10 minus

select * from b$i_exch_info where rownum < 5;

二、使用分析函式row_number分頁顯示

select *

from (select e.*, row_number() over(order by g3e_fid) r

from b$i_exch_info e) a

where a.r >= 5

and a.r <= 10;

select *

from table 

order by id

limit 10,20

資料庫實現分頁查詢顯示

現在一般用的比較多的資料庫,應該是oracle,mssql t sql mysql,但是他們並沒有統一的標準來實現分頁查詢,也就是沒有統一的sql標準,所以他們三個方法各不同給編碼人員造成了很大的不便。先總結一下,與大家共享!mysql 是最簡單的,就是使用limit進行查詢。例如 select f...

mfc CListCtrl分頁顯示資料庫資料

由於工程比較大,抽出部分 1 下面是查詢資料庫 m strquerysql getquerysql select from if m strquerysql recordsetptr pres null pres dbmanager getinstance queryoracledata m str...

從資料庫讀出資料分頁顯示

從資料庫中把資料讀出來 再渲染到頁面上 defbook view request book list book.objects.all return render request,book view.html 把讀取的內容交給頁面,然讓頁面交給瀏覽器 book list book.objects.a...