MySql、SqlServer、Oracle 三種資料庫查詢分頁方式

yubinfeng發表於2015-05-07

SQL Server
關於分頁 SQL 的資料許多,有的使用儲存過程,有的使用遊標。本人不喜歡使用遊標,我覺得它耗資、效率低;使用儲存過程是個不錯的選擇,因為儲存過程是顛末預編譯的,執行效率高,也更靈活。先看看單條 SQL 語句的分頁 SQL 吧。
方法1:
適用於 SQL Server 2000/2005
SELECT TOP 頁大小 * FROM table1 WHERE id NOT IN ( SELECT TOP 頁大小*(頁數-1) id FROM table1 ORDER BY id ) ORDER BY id
方法2:
適用於 SQL Server 2000/2005
SELECT TOP 頁大小 * FROM table1 WHERE id > ( SELECT ISNULL(MAX(id),0) FROM ( SELECT TOP 頁大小*(頁數-1) id FROM table1 ORDER BY id ) A ) ORDER BY id
方法3:
適用於 SQL Server 2005
SELECT TOP 頁大小 * FROM ( SELECT ROW_NUMBER() OVER (ORDER BY id) AS RowNumber,* FROM table1 ) A WHERE RowNumber > 頁大小*(頁數-1)
說明,頁大小:每頁的行數;頁數:第幾頁。使用時,請把“頁大小”以及“頁大小*(頁數-1)”替換成數碼。

MYSQL
SELECT * FROM TT LIMIT 1,20
SELECT * FROM TT LIMIT 21,30
/*
如果你是幾千上萬資料,就直接使用mysql自帶的函式 limit的普通用法就ok了,如果是100萬以上的資料,可能就要講方法了,下面我們來做個百萬級資料的分頁查詢語句.
mysql> select * from news where id>=(select id from news limit 490000,1) limit 10;    //0.18 sec  //很 明顯,這 種方式勝出 .
mysql> select * from news limit 490000,10  //0.22 sec;
*/
以下的文章主要介紹的是MySQL分頁的實際操作方案,其實關於實現MySQL分頁的最簡單的方法就是利用利用mysql資料庫的LIMIT函式,LIMIT [offset,] rows可以從MySQL資料庫表中第M條記錄開始檢索N條記錄的語句為:
 
 SELECT * FROM 表名稱 LIMIT M,N 
例如從表Sys_option(主鍵為sys_id)中從第10條記錄開始檢索20條記錄,語句如下:
select * from sys_option limit 10,20  
select * from table [查詢條件] order by id limit ?,?  
Oracle
Oracle的分頁查詢語句基本上可以按照這篇了,下一篇文章會通過例子來申述。下面簡單討論一下多表聯合的情況。對最多見的等值表連線查詢,CBO 一般可能會採用兩種連線方式NESTED LOOP以及HASH JOIN(MERGE JOIN效率比HASH JOIN效率低,一般CBO不會考慮)。在這裡,由於使用了分頁,因此指定了一個歸回的最大記載數,NESTED LOOP在歸回記載數跨越最大值時可以頓時遏制並將結果歸回給中心層,而HASH JOIN必需處理完所有成集(MERGE JOIN也是)。那麼在大部分的情況下,對分頁查詢選擇NESTED LOOP作為查詢的連線方法具有較高的效率(分頁查詢的時候絕大部分的情況是查詢前幾頁的資料,越靠後面的頁數訪問概率越小)。
因此,如果不介意在體系中使用HINT的話,可以將分頁的查詢語句改寫為:
SELECT /*+ FIRST_ROWS */ * FROM
(
SELECT A.*, ROWNUM RN
FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM <= 40
)
WHERE RN >= 21

相關文章