說說mysql和oracle他門的分頁查詢,分別是怎麼實現的?

MySQL:

  1. MySQL資料庫實現分頁比較簡單,提供了LIMIT函數。一般只需要直接寫到sql語句後面就行了。

  2. LIMIT子句可以用來限制由SELECT語句返回過來的數據數量,它有一個或兩個參數,如果給出兩個參數,第一個參數指定返回的第一行在所有數據中的位置,從0開始(注意不是1),第二個參數指定最多返回行數。例如:

select * from table WHERE … LIMIT 10; (返回前10行)

select * from table WHERE … LIMIT 0,10; (返回前10行)

select * from table WHERE … LIMIT 10,20; (返回第11-30行數據)

Oracle:

在oracle中沒有limit關鍵字,但是有rownum欄位,rownum是一個偽列,是oracle系統自動為查詢返回結果的每行分配的編號,第一行為1,第二行為2,以此類推。。。。

1.第一種程式碼如下:

SELECT * FROM

(SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME) A  WHERE ROWNUM <40)

WHERE RN >= 21

其中最內層的查詢SELECT * FROM TABLE_NAME表示不進行翻頁的原始查詢語句。ROWNUM <= 40和RN >= 21控制分頁查詢的每頁的範圍。

上面給出的這個分頁查詢語句,在大多數情況擁有較高的效率。分頁的目的就是控制輸出結果集大小,將結果儘快的返回。在上面的分頁查詢語句中,這種考慮主要體現在WHERE ROWNUM <= 40這句上。

選擇第21到40條記錄存在兩種方法,一種是上面例子中展示的在查詢的第二層通過ROWNUM <= 40來控制最大值,在查詢的最外層控制最小值。而另一種方式是去掉查詢第二層的WHERE ROWNUM <= 40語句,在查詢的最外層控制分頁的最小值和最大值。

2.第二種程式碼如下:

select * from

( select e.*,rownum  r from 

( select * from emp order by sal desc ) e 

) e1

where e1.r>
=21 and e1.r<=40;

e:按照工資降序排序並查詢所有的資訊。

e1:得到e查詢的值,並查詢出系統的rownum並指定上別名。這一句就比較關鍵,起了一個過渡的作用,首先要算出rownum來對e部分指定上序號,也可以為最外層部分用到這個變數。指定上查詢的開始記錄數和結束記錄的條件。

最外層部分:指定記錄從第幾條開始到第幾條結束,取出e1部分的值來作為查詢條件的變數

總結:

絕大多數的情況下,第一個查詢的效率比第二個高得多。

Tags: