最近看oracle資料的時候,瞭解rownum的概念,以前只知道對資料庫表進行簡單的增刪改查;
看到了rownum的概念後,突然想到了好多業務場景應該都可以適用的,比如在進行隨機發獎的時候,
我們就可以從先查一下獎品表中可以發的總獎品數,然後透過java的Random類在總獎品數內生成一個隨機整數X,然後呼叫
select * from (select rownum no,id from Table where rownum<=X ) where no >=X
獲取出該條獎品,這樣獲取出來的值,在一定的併發量的時候,發生拿到同一條資料的機率就比較小啦,為了支援高併發的情況,可以在考慮為獎品表增加一個樂觀鎖,
如果真的發生了同一條獎品被同時操作的時候,有了樂觀鎖,在獎品已經被髮之後,另外的一個程式再來發這個獎就會丟擲異常org.hibernate.StaleObjectStateException,然後我們就可以透過捕獲異常,然後重新給這個使用者去獎品表裡面來獲取獎品!
大致介紹一下rownum的使用吧!很多文章都介紹啦!
對於rownum來說它是oracle系統順序分配為從查詢返回的行的編號,返回的第一行分配的是1,第二行是2,依此類推,這個偽欄位可以用於限制查詢返回的總行數,且rownum不能以任何表的名稱作為字首。
1. rownum 對於等於某值的查詢條件
select rownum,id,name from student where rownum=1;這個是可以查出第一行資料的,但是當rownum不為1時,是無法查詢出來資料的;如
select rownum,id,name from student where rownum =2;這個就無法查詢出資料;
2.rownum對於大於某值的查詢條件
select * from(select rownum no ,id,name from student) where no>2;查詢rownum大於某值時,必須要使用子查詢的方式才可以,且內部的select中的rownum必須使用別名,否則外部查詢條件是無法正常定位rownum是指內部的rownum
3.rownum對於小於某值的查詢條件
select rownum,id,name from student where rownum <3;查詢前2行的資料,這樣是可以直接查詢到的,因為rownum<3時,rownum是從1開始遞增的,符合rownum的生成規律
select rownum,id,name from student where rownum <=2;這樣也是可以的
4.rownum和排序
select rownum ,id,name from (select * from student order by name);首先要了解rownum的概念,rownum是在資料查詢出來後,系統遞增的給每行資料分配一個編號;如果使用
select rownum ,id,name from student order by name;則生成的序號則是以下情況;因為order by是先查詢,查詢出來後在進行排序,也就是在排序前,rownum就已經有值啦!
3 200003 李三
2 200002 王二
1 200001 張一
4 200004 趙四
5.獲取某行資料的方法
select * from (select rownum r,a from yourtable where rownum <= 5 order by name )where r >4;這樣就可以獲取到第5行資料,且是以name排序後的第5行資料
轉自: