Oracle結(jié)合Mybatis實現(xiàn)取表TOP 10條數(shù)據(jù)
之前一直使用mysql和informix數(shù)據(jù)庫,查表中前10條數(shù)據(jù)十分簡單:
最原始版本:
select top * from student
當(dāng)然,我們還可以寫的復(fù)雜一點,比如外加一些查詢條件?
比如查詢前10條成績大于80分的學(xué)生信息
添加了where查詢條件的版本:
select top * from table where score > 80
但是??!oracle中沒有top?。。。。∧敲丛撊绾螌崿F(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
簡單分析一下上面的代碼。實際上是先通過內(nèi)嵌的sql語句查詢出分?jǐn)?shù)大于80的數(shù)據(jù),再選擇內(nèi)嵌sql查詢結(jié)果中的前10條數(shù)據(jù)
最后附上mybatis代碼?
<select id="selectStudent" parameterType="hashmap" resultMap="BaseResultMap">
select *
from (
select rownum rn, A.* from student A
where STATUS = '99'
and score <![CDATA[>]]> #{scores,jdbcType=INTEGER})
where rn <![CDATA[<=]]> #{number,jdbcType=INTEGER}
</select>
上面的scores和number均為變量
ps:mybatis取Oracle序列,值相同問題處理
<select id="getCode" resultType="java.lang.String"> select 'TRD'||to_char(sysdate,'yyyymmdd')||lpad(to_char(SQ_ORD_PURCHASE_ID.nextval), 5, '0') code from dual </select>
上述mybatis代碼在調(diào)用是總是獲取到同一個序列的值,查詢相關(guān)資料得知是mybatis的緩存問題:
加上useCache="false" flushCache="false" 屬性即可:
<select id="getCode" resultType="java.lang.String" useCache="false" flushCache="false"> select 'TRD'||to_char(sysdate,'yyyymmdd')||lpad(to_char(SQ_ORD_PURCHASE_ID.nextval), 5, '0') code from dual </select>
總結(jié)
以上所述是小編給大家介紹的Oracle結(jié)合Mybatis實現(xiàn)取表TOP 10條數(shù)據(jù),希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
相關(guān)文章
Oracle服務(wù)器結(jié)構(gòu)詳解(最新推薦)
這篇文章主要介紹了Oracle服務(wù)器結(jié)構(gòu)的相關(guān)知識,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-06-06
oracle中如何獲得數(shù)據(jù)庫的DBID信息
在進(jìn)行數(shù)據(jù)庫恢復(fù)的過程中,很多時候我們需要知道Oracle數(shù)據(jù)庫的DBID,通常有以下幾種方法可以獲得數(shù)據(jù)庫的DBID2013-09-09
Oracle顯示游標(biāo)的使用及游標(biāo)for循環(huán)
本篇文章給大家介紹oracle顯示游標(biāo)的使用及游標(biāo)for循環(huán),當(dāng)查詢返回單行記錄時使用隱式游標(biāo),查詢返回多行記錄并逐行進(jìn)行處理時使用顯式游標(biāo),對本文感興趣的朋友一起學(xué)習(xí)吧2015-11-11
Oracle中sys和system的區(qū)別小結(jié)
SYS用戶具有DBA權(quán)限,并且擁有SYS模式,只能通過SYSDBA登陸數(shù)據(jù)庫。是Oracle數(shù)據(jù)庫中權(quán)限最高的帳號 SYSTEM具有DBA權(quán)限。但沒有SYSDBA權(quán)限。平常一般用該帳號管理數(shù)據(jù)庫就可以了。2009-11-11
淺談Oracle 11g 發(fā)行版2 新安裝后關(guān)于登錄的一些基本操作
oracle 11g的兩個不同版本。11g剛發(fā)行時,是11g第一版,簡稱11.1,現(xiàn)在有個11g第二版,在功能上有了更多的改進(jìn),簡稱11.2。本文給大家介紹Oracle 11g 發(fā)行版2 新安裝后關(guān)于登錄的一些基本操作,需要的朋友可以參考下2015-10-10

