因?yàn)镺racle數(shù)據(jù)庫(kù)沒有Top關(guān)鍵字,所以這里就不能夠像微軟的數(shù)據(jù)據(jù)那樣操作,這里有兩種方法:
創(chuàng)新互聯(lián)公司專注于企業(yè)網(wǎng)絡(luò)營(yíng)銷推廣、網(wǎng)站重做改版、六合網(wǎng)站定制設(shè)計(jì)、自適應(yīng)品牌網(wǎng)站建設(shè)、H5高端網(wǎng)站建設(shè)、商城網(wǎng)站定制開發(fā)、集團(tuán)公司官網(wǎng)建設(shè)、外貿(mào)網(wǎng)站制作、高端網(wǎng)站制作、響應(yīng)式網(wǎng)頁(yè)設(shè)計(jì)等建站業(yè)務(wù),價(jià)格優(yōu)惠性價(jià)比高,為六合等各大城市提供網(wǎng)站開發(fā)制作服務(wù)。
一種是利用相反的。
PAGESIZE:每頁(yè)顯示的記錄數(shù)
CURRENTPAGE:當(dāng)前頁(yè)號(hào)
數(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,這個(gè)是Oracle查詢自動(dòng)返回的序號(hào),一般不顯示,但是可以通過select rownum from [表名],可以看到,是從1到當(dāng)前的記錄總數(shù)。
select * from (select rownum tid,components.* from components where rownum=100) where tid=10;
oracle,
sql
server
和mysql的分頁(yè)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
公認(rèn)第二種方法效率沒有第一種高。原因是第二種要把子查詢執(zhí)行完,而第一種方法子查詢執(zhí)行到rownum=40后就結(jié)束了。mysql:
select
*
from
table_name
limit
10,
20
表示從第11條數(shù)據(jù)開始取20條數(shù)據(jù)返回,limit后的2個(gè)參數(shù)含義為:起點(diǎn)和步長(zhǎng),即從那條數(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
sql語句如下:
分頁(yè)1
SELECT *
FROM (Select ROWNUM AS ROWNO, T.*
from 表名 T(別名)
where 表字段 between to_date('20060501', 'yyyymmdd') and ?to_date('20060731', 'yyyymmdd')
AND ROWNUM = 20) TABLE_ALIAS
WHERE TABLE_ALIAS.ROWNO = 10;
經(jīng)過測(cè)試,此方法成本最低,只嵌套一層,速度最快,即使查詢的數(shù)據(jù)量再大,也幾乎不受影響,速度依然.
分頁(yè)2:
SELECT *
FROM (SELECT TT.*, ROWNUM AS ROWNO
FROM (Select t.*
? ? from 表名 T(別名)
? ? where flight_date between to_date('20060501', 'yyyymmdd') and
? ? ? ?to_date('20060531', 'yyyymmdd')
? ? ORDER BY FACT_UP_TIME, flight_no) TT(別名二)
WHERE ROWNUM = 20) TABLE_ALIAS
where TABLE_ALIAS.rowno = 10;
經(jīng)過測(cè)試,此方法隨著查詢范圍的擴(kuò)大,速度也會(huì)越來越慢,
SELECT * FROM
(SELECT A.*, ROWNUM RN FROM (SELECT * FROM TABLE_NAME) A
WHERE ROWNUM = 40
)
WHERE RN = 21
其中最內(nèi)層的查詢SELECT * FROM TABLE_NAME表示不進(jìn)行翻頁(yè)的原始查詢語句。ROWNUM = 40和RN = 21控制分頁(yè)查詢的每頁(yè)的范圍。主要就是靠oracle的偽列rownum來控制。
在Oracle中有一個(gè)方法rownum用來查詢第一行到第n行的內(nèi)容,但沒有一個(gè)合適的方法若查詢第x行到第y行的內(nèi)容,而在實(shí)際應(yīng)用中卻經(jīng)常需要查詢第x行到第y行的內(nèi)容,這時(shí)我們就需要使用rownum和子表查詢等內(nèi)容來進(jìn)行查詢,因?yàn)檫@一塊內(nèi)容屬于Oracle總的常用部分所以專門在此介紹。
在Oralce中有一個(gè)偽列rownum,其在創(chuàng)建表的時(shí)候就存在了卻不顯示,若要使用這個(gè)列可以直接調(diào)用即可,也可以對(duì)這個(gè)列添加別名來調(diào)用。
rownum只能用于顯示小于某行的數(shù)據(jù)即第一行開始到你要查詢到的那一行為止的數(shù)據(jù)。
在Oracle把查詢第幾行到第幾行的操作稱為分頁(yè),其具體操作是通過子查詢等操作完成。
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;
這一步可以精簡(jiǎn)為下面形式,但某些情況只能用上面那種
select emp.*,rownum rn from emp;
3.查詢
select * from(select e.*,rownum rn from (select * from emp)e);
4.其他變化
在某些時(shí)候我們需要先對(duì)表的內(nèi)容進(jìn)行排序,隨后查詢第x行到第y行的內(nèi)容,這個(gè)時(shí)候有一個(gè)需要注意的點(diǎn)是rownum是在表產(chǎn)生的時(shí)候產(chǎn)生的偽列,所以使用排序會(huì)連著rownum的值進(jìn)行排序,從而達(dá)不到想要的效果。
為了解決上述這個(gè)問題,我們需要使用子表查詢即先排好序,再在新表之中顯示rownum來規(guī)避這個(gè)問題。
考慮到排序的問題,所以在上方第二步的時(shí)候使用第一種方法即select e.*,rownum rn from(select * from emp)e;,在內(nèi)表select * from emp中進(jìn)行排序可以完成在亂序中找到第x行到第y行的效果。
標(biāo)題名稱:oracle分頁(yè)怎么算,oracle簡(jiǎn)單分頁(yè)
URL標(biāo)題:http://vcdvsql.cn/article22/hshsjc.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供云服務(wù)器、微信公眾號(hào)、網(wǎng)站收錄、關(guān)鍵詞優(yōu)化、軟件開發(fā)、靜態(tài)網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容