前提:
成都創(chuàng)新互聯(lián)長期為成百上千家客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊(duì)從業(yè)經(jīng)驗(yàn)10年,關(guān)注不同地域、不同群體,并針對(duì)不同對(duì)象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺(tái),與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為東臺(tái)企業(yè)提供專業(yè)的成都做網(wǎng)站、網(wǎng)站設(shè)計(jì),東臺(tái)網(wǎng)站改版等技術(shù)服務(wù)。擁有十多年豐富建站經(jīng)驗(yàn)和眾多成功案例,為您定制開發(fā)。
分頁參數(shù):size = 20 page = 2;
沒有order by的查詢;
嵌套子查詢,兩次篩選(推薦使用)。
SQL語句:
SELECT *
FROM (SELECT ROWNUM AS rowno, t.*
FROM DONORINFO t
WHERE t.BIRTHDAY BETWEEN TO_DATE ('19800101', 'yyyymmdd')
AND TO_DATE ('20060731', 'yyyymmdd')
AND ROWNUM = 20*2) table_alias
WHERE table_alias.rowno 20*(2-1);
擴(kuò)展資料:
rownum總是從1開始的,第一條不滿足去掉的話,第二條的rownum 又成了1。依此類推,所以永遠(yuǎn)沒有不滿足條件的記錄。
可以這樣理解:rownum是一個(gè)序列,是Oracle數(shù)據(jù)庫從數(shù)據(jù)文件或緩沖區(qū)中讀取數(shù)據(jù)的順序。它取得第一條記錄則rownum值為1,第二條為2。
依次類推:當(dāng)使用“、=、=、between...and”這些條件時(shí),從緩沖區(qū)或數(shù)據(jù)文件中得到的第一條記錄的rownum為1,不符合sql語句的條件,會(huì)被刪除,接著取下條。下條的rownum還會(huì)是1,又被刪除,依次類推,便沒有了數(shù)據(jù)。
因?yàn)镺racle數(shù)據(jù)庫沒有Top關(guān)鍵字,所以這里就不能夠像微軟的數(shù)據(jù)據(jù)那樣操作,這里有兩種方法:
一種是利用相反的。
PAGESIZE:每頁顯示的記錄數(shù)
CURRENTPAGE:當(dāng)前頁號(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中有一個(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把查詢第幾行到第幾行的操作稱為分頁,其具體操作是通過子查詢等操作完成。
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.其他變化
在某些時(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行的效果。