小編給大家分享一下Oracle結(jié)合Mybatis如何實(shí)現(xiàn)取表中前10條數(shù)據(jù),相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
創(chuàng)新互聯(lián)于2013年成立,公司以網(wǎng)站設(shè)計(jì)制作、成都網(wǎng)站制作、系統(tǒng)開發(fā)、網(wǎng)絡(luò)推廣、文化傳媒、企業(yè)宣傳、平面廣告設(shè)計(jì)等為主要業(yè)務(wù),適用行業(yè)近百種。服務(wù)企業(yè)客戶1000+,涉及國內(nèi)多個省份客戶。擁有多年網(wǎng)站建設(shè)開發(fā)經(jīng)驗(yàn)。為企業(yè)提供專業(yè)的網(wǎng)站建設(shè)、創(chuàng)意設(shè)計(jì)、宣傳推廣等服務(wù)。 通過專業(yè)的設(shè)計(jì)、獨(dú)特的風(fēng)格,為不同客戶提供各種風(fēng)格的特色服務(wù)。之前一直使用mysql和informix數(shù)據(jù)庫,查表中前10條數(shù)據(jù)十分簡單:
最原始版本:
select top * from student
當(dāng)然,我們還可以寫的復(fù)雜一點(diǎn),比如外加一些查詢條件?
比如查詢前10條成績大于80分的學(xué)生信息
添加了where查詢條件的版本:
select top * from table where score > 80
但是?。racle中沒有top?。。。?!那么該如何實(shí)現(xiàn)呢?
嗯,可以用rownum!
oracle中原始版本
select * from student where rownum < 10
上面這個好像也沒有復(fù)雜的地方。。但是問題來了,如果我們還希望加上分?jǐn)?shù)大于80呢?
對于我這個oracle初學(xué)者來說,真的是費(fèi)力。在這里就直接貼出來了,希望可以讓一些人少費(fèi)一些力!
oracle添加了where查詢條件的版本
select * from( select rownum rn,A.* from student where score > 80) where rn < 10
簡單分析一下上面的代碼。實(shí)際上是先通過內(nèi)嵌的sql語句查詢出分?jǐn)?shù)大于80的數(shù)據(jù),再選擇內(nèi)嵌sql查詢結(jié)果中的前10條數(shù)據(jù)
最后附上mybatis代碼?
上面的scores和number均為變量
ps:mybatis取Oracle序列,值相同問題處理
上述mybatis代碼在調(diào)用是總是獲取到同一個序列的值,查詢相關(guān)資料得知是mybatis的緩存問題:
加上useCache="false" flushCache="false"
屬性即可:
以上是“Oracle結(jié)合Mybatis如何實(shí)現(xiàn)取表中前10條數(shù)據(jù)”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對大家有所幫助,如果還想學(xué)習(xí)更多知識,歡迎關(guān)注創(chuàng)新互聯(lián)成都網(wǎng)站設(shè)計(jì)公司行業(yè)資訊頻道!
另外有需要云服務(wù)器可以了解下創(chuàng)新互聯(lián)scvps.cn,海內(nèi)外云服務(wù)器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務(wù)器、裸金屬服務(wù)器、高防服務(wù)器、香港服務(wù)器、美國服務(wù)器、虛擬主機(jī)、免備案服務(wù)器”等云主機(jī)租用服務(wù)以及企業(yè)上云的綜合解決方案,具有“安全穩(wěn)定、簡單易用、服務(wù)可用性高、性價比高”等特點(diǎn)與優(yōu)勢,專為企業(yè)上云打造定制,能夠滿足用戶豐富、多元化的應(yīng)用場景需求。