Oracle分頁查詢格式:\x0d\x0a以下是代碼片段:\x0d\x0aSELECT * FROM\x0d\x0a(\x0d\x0aSELECT A.*, ROWNUM RN\x0d\x0aFROM (SELECT * FROM TABLE_NAME) A\x0d\x0aWHERE ROWNUM = 21\x0d\x0a \x0d\x0amysql\x0d\x0amysql SELECT * FROM table LIMIT 5,10; // 檢索記錄行 6-15 ,注意,10為偏移量\x0d\x0a//為了檢索從某一個偏移量到記錄集的結(jié)束所有的記錄行,可以指定第二個參數(shù)為 -1:\x0d\x0amysql SELECT * FROM table LIMIT 95,-1; // 檢索記錄行 96-last.\x0d\x0a//如果只給定一個參數(shù),它表示返回最大的記錄行數(shù)目:\x0d\x0amysql SELECT * FROM table LIMIT 5; //檢索前 5 個記錄行 //也就是說,LIMIT n 等價于 LIMIT 0,n。
創(chuàng)新互聯(lián)建站從2013年開始,先為樂安等服務(wù)建站,樂安等地企業(yè),進行企業(yè)商務(wù)咨詢服務(wù)。為樂安企業(yè)網(wǎng)站制作PC+手機+微官網(wǎng)三網(wǎng)同步一站式服務(wù)解決您的所有建站問題。
oracle,
sql
server
和mysql的分頁sql語句如下:oracle:方法一:select
*
from(select
a.*,
rownum
rn
from
(select
*
from
table_name)
a
where
rownum
=
40)where
rn
=
21;方法二:select
*
from(select
a.*,
rownum
rn
from
(select
*
from
table_name)
a)where
rn
between
21
and
40
公認第二種方法效率沒有第一種高。原因是第二種要把子查詢執(zhí)行完,而第一種方法子查詢執(zhí)行到rownum=40后就結(jié)束了。mysql:
select
*
from
table_name
limit
10,
20
表示從第11條數(shù)據(jù)開始取20條數(shù)據(jù)返回,limit后的2個參數(shù)含義為:起點和步長,即從那條數(shù)據(jù)開始,取多少條數(shù)據(jù),再如取前20條數(shù)據(jù):select
*
from
table_name
limit
0,
20
sql
server2000:
select
top
@pagesize
*
from
table_name
where
id
not
in
(select
top
@pagesize*(@page-1)
id
from
table_name
order
by
id)
order
by
id
因為Oracle數(shù)據(jù)庫沒有Top關(guān)鍵字,所以這里就不能夠像微軟的數(shù)據(jù)據(jù)那樣操作,這里有兩種方法:
一種是利用相反的。
PAGESIZE:每頁顯示的記錄數(shù)
CURRENTPAGE:當(dāng)前頁號
數(shù)據(jù)表的名字是:components
索引主鍵字是:id
select * from components where id not in(select id from components where rownum=(PAGESIZE*(CURRENTPAGE-1))) and rownum=PAGESIZE order by id;
如下例:
select * from components where id not in(select id from components where rownum=100) and rownum=10 order by id;
從101到記錄開始選擇,選擇前面10條。
使用minus,即中文的意思就是減去,呵呵,這語句非常的有意思,也非常好記
select * from components where rownum=(PAGESIZE*(CURRENTPAGE-1)) minus select * from components where rownum=(PAGESIZE*(CURRENTPAGE-2));
如例:select * from components where rownum=10 minus select * from
一種是利用Oracle的rownum,這個是Oracle查詢自動返回的序號,一般不顯示,但是可以通過select rownum from [表名],可以看到,是從1到當(dāng)前的記錄總數(shù)。
select * from (select rownum tid,components.* from components where rownum=100) where tid=10;
在Oracle中有一個方法rownum用來查詢第一行到第n行的內(nèi)容,但沒有一個合適的方法若查詢第x行到第y行的內(nèi)容,而在實際應(yīng)用中卻經(jīng)常需要查詢第x行到第y行的內(nèi)容,這時我們就需要使用rownum和子表查詢等內(nèi)容來進行查詢,因為這一塊內(nèi)容屬于Oracle總的常用部分所以專門在此介紹。
在Oralce中有一個偽列rownum,其在創(chuàng)建表的時候就存在了卻不顯示,若要使用這個列可以直接調(diào)用即可,也可以對這個列添加別名來調(diào)用。
rownum只能用于顯示小于某行的數(shù)據(jù)即第一行開始到你要查詢到的那一行為止的數(shù)據(jù)。
在Oracle把查詢第幾行到第幾行的操作稱為分頁,其具體操作是通過子查詢等操作完成。
select 列名 from (select 表名.*,rownum rn from 表名)表名 ?where rn操作;
思考如下:
1.選擇所有內(nèi)容
select * from emp;
2.顯示rownum
select e.*,rownum rn from(select * from emp)e;
這一步可以精簡為下面形式,但某些情況只能用上面那種
select emp.*,rownum rn from emp;
3.查詢
select * from(select e.*,rownum rn from (select * from emp)e);
4.其他變化
在某些時候我們需要先對表的內(nèi)容進行排序,隨后查詢第x行到第y行的內(nèi)容,這個時候有一個需要注意的點是rownum是在表產(chǎn)生的時候產(chǎn)生的偽列,所以使用排序會連著rownum的值進行排序,從而達不到想要的效果。
為了解決上述這個問題,我們需要使用子表查詢即先排好序,再在新表之中顯示rownum來規(guī)避這個問題。
考慮到排序的問題,所以在上方第二步的時候使用第一種方法即select e.*,rownum rn from(select * from emp)e;,在內(nèi)表select * from emp中進行排序可以完成在亂序中找到第x行到第y行的效果。
因為一個功能需要讀取一個大表的所有數(shù)據(jù)做業(yè)務(wù)處理,那這樣肯定不能一次性查出所有數(shù)據(jù),需要程序分頁查詢處理,模擬測試一個200萬數(shù)據(jù)量的表發(fā)現(xiàn)耗時很久,并不是業(yè)務(wù)處理耗時,而且分頁查詢耗時了。oracle的分頁查詢可能大家都知道利用rownum,而且大部分公司這種分頁都是底層封裝好的了,所有平時大家使用的時候也沒注意(這次之后特意留意了一下,我們公司就是用了錯誤的)
這兩條查詢語句看著區(qū)別不大,但是性能卻差很多。經(jīng)過測試第一種性能最好,而且隨著數(shù)量的增大,幾乎不受影響。第二種隨著數(shù)據(jù)量的增大,查詢速度也越來越慢。表200W條數(shù)據(jù)的情況下,第一種查詢耗時基本是0.3s,第二種基本在1.3s以上。一個查詢足足差了一秒。別小看這1秒。200W條數(shù)據(jù)每次查詢1000條,查詢完也差了2000s=33分鐘.
分頁的目的就是控制輸出結(jié)果集大小,將結(jié)果盡快的返回。在上面的分頁查詢語句中,這種考慮主要體現(xiàn)在WHERE ROWNUM = 20這句上。
這是由于CBO優(yōu)化模式下,Oracle可以將外層的查詢條件推到內(nèi)層查詢中,以提高內(nèi)層查詢的執(zhí)行效率。
對于正確有order by語句,第二層的查詢條件WHERE ROWNUM = 20就可以被Oracle推入到內(nèi)層查詢中,這樣Oracle查詢的結(jié)果一旦超過了ROWNUM限制條件,就終止查詢將結(jié)果返回了
對于錯誤有order by 語句,由于查詢條件where b.rowno = 11 and b.rowno = 20是存在于查詢的第三層,而Oracle無法將第三層的查詢條件推到最內(nèi)層(即使推到最內(nèi)層也沒有意義,因為最內(nèi)層查詢不知道b.rowno代表什么)。因此對于這個語句,Oracle最內(nèi)層返回給中間層的是所有滿足條件的數(shù)據(jù),而中間層返回給最外層的也是所有數(shù)據(jù)。數(shù)據(jù)的過濾在最外層完成,顯然這個效率要比第一個查詢低得多。
上面分析的查詢不僅僅是針對單表的簡單查詢,對于最內(nèi)層查詢是復(fù)雜的多表聯(lián)合查詢或最內(nèi)層查詢包含排序的情況一樣有效。
1.rownum分頁查詢:select t2.* from (select t1.*,rownum as rn from table_name t1 where 1=1 and rownum = page * page_size) t2 where t2.rn (page - 1) * page_size;2. row_number() over() 分頁查詢select t2.* from (select t1.*,row_number() over(order by column_name desc) as rn from table_name t1 where 1=1 )t2 where t2.rn (page-1)* page_size and t2.rn = page * page_size;