日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

Oracle的rownum原理和使用

發布時間:2024/4/14 编程问答 31 豆豆
生活随笔 收集整理的這篇文章主要介紹了 Oracle的rownum原理和使用 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

俺程序中用到的rownum分頁+排序的實現(有機會仔細研究)

?

select * from (select f.*, rownum as rnum from (select a.CIPID as cipId ,CIP_ORDERNO as orderNo ,CIP_approveNo as approveNo ,d.CIP_SYSDATE as cipSysDate ,d.CIP_issueDate as issueDate ,d.CIP_STATUS as status ,decode(CIP_rapidType,null,0,CIP_rapidType) as rapidType from Cip_standardInfo a, Cip_standardAttribute b, Cip_standardRemark c, Cip_standardStatus d , CIP_GLOBLEINFO f , Cip_currentTask task where a.CIPID=b.CIPID and a.CIPID=c.CIPID and a.CIPID = d.CIPID and a.CIPID=f.CIPID(+) and a.cipid=task.cipid(+) order by a.CIP_ORDERNO DESC)f where rownum<5 )where rnum>1

?

?

?

Oracle的rownum原理和使用
在Oracle中,要按特定條件查詢前N條記錄,用個rownum就搞定了。
select * from emp where rownum <= 5
而且書上也告誡,不能對rownum用">",這也就意味著,如果你想用
select * from emp where rownum > 5
則是失敗的。要知道為什么會失敗,則需要了解rownum背后的機制:
1 Oracle executes your query.

2 Oracle fetches the first row and calls it row number 1.

3 Have we gotten past row number meets the criteria? If no, then Oracle discards the row, If yes, then Oracle return the row.

4 Oracle fetches the next row and advances the row number (to 2, and then to 3, and then to 4, and so forth).

5 Go to step 3.

了解了原理,就知道rownum>不會成功,因為在第三步的時候查詢出的行已經被丟棄,第四步查出來的rownum仍然是1,這樣永遠也不會成功。

同樣道理,rownum如果單獨用=,也只有在rownum=1時才有用。



對于rownum來說它是oracle系統順序分配為從查詢返回的行的編號,返回的第一行分配的是1,第二行是2,依此類推,這個偽字段可以用于限制查詢返回的總行數,而且rownum不能以任何表的名稱作為前綴。
舉例說明:
例如表:student(學生)表,表結構為:
ID   ??? char(6)      --學號
name    VARCHAR2(10)   --姓名
create table student (ID char(6), name VARCHAR2(100));
insert into sale values('200001',‘張一’);
insert into sale values('200002',‘王二’);
insert into sale values('200003',‘李三’);
insert into sale values('200004',‘趙四’);
commit;
(1) rownum 對于等于某值的查詢條件
如果希望找到學生表中第一條學生的信息,可以使用rownum=1作為條件。但是想找到學生表中第二條學生的信息,使用rownum=2結果查不到數據。因為rownum都是從1開始,但是1以上的自然數在rownum做等于判斷是時認為都是false條件,所以無法查到rownum = n(n>1的自然數)。
SQL> select rownum,id,name from student where rownum=1;(可以用在限制返回記錄條數的地方,保證不出錯,如:隱式游標)
SQL> select rownum,id,name from student where rownum=1;
??? ROWNUM ID???? NAME
---------- ------ ---------------------------------------------------
???????? 1 200001 張一
SQL> select rownum,id,name from student where rownum =2;
??? ROWNUM ID???? NAME
---------- ------ ---------------------------------------------------
(2)rownum對于大于某值的查詢條件
?? 如果想找到從第二行記錄以后的記錄,當使用rownum>2是查不出記錄的,原因是由于rownum是一個總是從1開始的偽列,Oracle 認為rownum> n(n>1的自然數)這種條件依舊不成立,所以查不到記錄
SQL> select rownum,id,name from student where rownum >2;
ROWNUM ID???? NAME
---------- ------ ---------------------------------------------------
那如何才能找到第二行以后的記錄呀。可以使用以下的子查詢方法來解決。注意子查詢中的rownum必須要有別名,否則還是不會查出記錄來,這是因為rownum不是某個表的列,如果不起別名的話,無法知道rownum是子查詢的列還是主查詢的列。
SQL>select * from(select rownum no ,id,name from student) where no>2;
??????? NO ID???? NAME
---------- ------ ---------------------------------------------------
???????? 3 200003 李三
???????? 4 200004 趙四
SQL> select * from(select rownum,id,name from student)where rownum>2;
??? ROWNUM ID???? NAME
---------- ------ ---------------------------------------------------
(3)rownum對于小于某值的查詢條件
如果想找到第三條記錄以前的記錄,當使用rownum<3是能得到兩條記錄的。顯然rownum對于rownum<n((n>1的自然數)的條件認為是成立的,所以可以找到記錄。
SQL> select rownum,id,name from student where rownum <3;
??? ROWNUM ID???? NAME
---------- ------ ---------------------------------------------------
1 200001 張一
??????? 2 200002 王二
綜上幾種情況,可能有時候需要查詢rownum在某區間的數據,那怎么辦呀從上可以看出rownum對小于某值的查詢條件是人為true的,rownum對于大于某值的查詢條件直接認為是false的,但是可以間接的讓它轉為認為是true的。那就必須使用子查詢。例如要查詢rownum在第二行到第三行之間的數據,包括第二行和第三行數據,那么我們只能寫以下語句,先讓它返回小于等于三的記錄行,然后在主查詢中判斷新的rownum的別名列大于等于二的記錄行。但是這樣的操作會在大數據集中影響速度。
SQL> select * from (select rownum no,id,name from student where rownum<=3 ) where no >=2;
??????? NO ID???? NAME
---------- ------ ---------------------------------------------------
???????? 2 200002 王二
???????? 3 200003 李三
(4)rownum和排序
Oracle中的rownum的是在取數據的時候產生的序號,所以想對指定排序的數據去指定的rowmun行數據就必須注意了。
SQL> select rownum ,id,name from student order by name;
??? ROWNUM ID???? NAME
---------- ------ ---------------------------------------------------
???????? 3 200003 李三
???????? 2 200002 王二
???????? 1 200001 張一
???????? 4 200004 趙四
可以看出,rownum并不是按照name列來生成的序號。系統是按照記錄插入時的順序給記錄排的號,rowid也是順序分配的。為了解決這個問題,必須使用子查詢
SQL> select rownum ,id,name from (select * from student order by name);
??? ROWNUM ID???? NAME
---------- ------ ---------------------------------------------------
???????? 1 200003 李三
???????? 2 200002 王二
???????? 3 200001 張一
???????? 4 200004 趙四
這樣就成了按name排序,并且用rownum標出正確序號(有小到大)

總結

以上是生活随笔為你收集整理的Oracle的rownum原理和使用的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 污导航在线| 特级黄色录像 | 亚洲欧美日韩一区二区 | 国产一级做a爰片久久毛片男男 | 亚洲一区自拍 | 国模私拍一区二区三区 | 欧美黄色特级视频 | 香港三级在线视频 | 羞辱极度绿帽vk | 国产无人区码熟妇毛片多 | 久久重口味 | 伊人影院综合在线 | 亚洲综合情 | 国产99久久久 | 日本亚洲在线 | 久久精品一区二区免费播放 | 亚洲精品福利视频 | 亚洲午夜久久 | 黄色工厂在线观看 | 美女在线国产 | 国产suv精品一区二区四 | 欧美卡一卡二卡三 | 亚洲视频1区 | 中国一级特黄真人毛片免费观看 | 狠狠插狠狠操 | 国产不卡视频 | 久久久中文网 | 成人a在线 | 欧美性猛交xxxx乱大交hd | 天天做天天爱天天爽 | 国产中文在线播放 | av一区二区在线播放 | 免费观看久久久 | 国产精品23p| 午夜精品福利一区二区蜜股av | 久久99精品视频 | 天天做天天躁天天躁 | 不卡一区在线 | 综合色亚洲 | 午夜视频免费在线 | 久久精品一区二区三区黑人印度 | 日日噜噜夜夜狠狠久久波多野 | 烈性摔跤| 青娱乐精品视频 | 黄色片视频免费在线观看 | 操操操网| 色婷婷av一区二区三区之e本道 | 蜜臀精品一区二区三区 | 国产三区在线观看 | 五月天激情影院 | 久久99久久99精品免视看婷婷 | 久久精品欧美一区二区三区不卡 | 亚洲国产精品免费视频 | 日日摸天天添天天添破 | 日本免费在线观看视频 | 黄色自拍视频 | 野花av| 美女福利视频在线 | 久久婷婷综合色丁香五月 | 黄色99视频| 久久观看 | 91精品国产91久久久久久吃药 | 在线看片你懂 | 成人免费版 | 亚洲美女自拍视频 | 日本高清中文字幕 | 女人天堂网站 | 精品国产乱码久久久久久闺蜜 | 亚洲一区日本 | 日本少妇全体裸体洗澡 | 侵犯亲女在线播放视频 | 中文av一区二区三区 | 亚洲久爱| 国产精品一二区在线观看 | 中文字幕日韩久久 | 精品aaa| 日本午夜网站 | 国产成人看片 | 色女综合| 色爱成人综合 | 九九爱精品| 中文字幕淫 | 欧美日韩亚洲色图 | 欧美精品v国产精品v日韩精品 | 色呦呦在线免费观看 | 日本一级三级三级三级 | 午夜大片网 | 成人刺激视频 | 国产精品vip| 国产麻豆交换夫妇 | 顶级嫩模啪啪呻吟不断好爽 | 免费v片在线观看 | 色狠狠操 | 国产片黄色 | 国产精品成人在线观看 | 亚洲精品久久久久久久蜜桃臀 | aaa级黄色片 | 91视频二区 | 日韩三级中文 |