Oracle结合Mybatis实现取表TOP 10条数据

 更新时间:2017年11月03日 08:43:26   作者:四度空间的平面  
这篇文章主要介绍了Oracle结合Mybatis实现取表TOP 10条数据的相关资料,需要的朋友可以参考下

之前一直使用mysql和informix数据库,查表中前10条数据十分简单:

最原始版本:

select top * from student

当然,我们还可以写的复杂一点,比如外加一些查询条件?

比如查询前10条成绩大于80分的学生信息 

添加了where查询条件的版本:

select top * from table where score > 80 

但是!!oracle中没有top啊!!!!那么该如何实现呢?

嗯,可以用rownum!

oracle中原始版本

select * from student where rownum < 10

上面这个好像也没有复杂的地方。。但是问题来了,如果我们还希望加上分数大于80呢?

对于我这个oracle初学者来说,真的是费力。在这里就直接贴出来了,希望可以让一些人少费一些力! 

oracle添加了where查询条件的版本

select * from(
  select rownum rn,A.* from student where score > 80) 
where rn < 10

简单分析一下上面的代码。实际上是先通过内嵌的sql语句查询出分数大于80的数据,再选择内嵌sql查询结果中的前10条数据 

最后附上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代码在调用是总是获取到同一个序列的值,查询相关资料得知是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>

总结

以上所述是小编给大家介绍的Oracle结合Mybatis实现取表TOP 10条数据,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对脚本之家网站的支持!

相关文章

  • Oracle服务器结构详解(最新推荐)

    Oracle服务器结构详解(最新推荐)

    这篇文章主要介绍了Oracle服务器结构的相关知识,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧
    2024-06-06
  • Oracle 随机数

    Oracle 随机数

    用于抽样统计,从数据库中按类别随机 抽取各类用户
    2009-05-05
  • oracle中如何获得数据库的DBID信息

    oracle中如何获得数据库的DBID信息

    在进行数据库恢复的过程中,很多时候我们需要知道Oracle数据库的DBID,通常有以下几种方法可以获得数据库的DBID
    2013-09-09
  • Oracle PL/SQL语言入门基础

    Oracle PL/SQL语言入门基础

    Oracle PL/SQL语言入门基础...
    2007-03-03
  • Oracle显示游标的使用及游标for循环

    Oracle显示游标的使用及游标for循环

    本篇文章给大家介绍oracle显示游标的使用及游标for循环,当查询返回单行记录时使用隐式游标,查询返回多行记录并逐行进行处理时使用显式游标,对本文感兴趣的朋友一起学习吧
    2015-11-11
  • oracle锁表该如何解决

    oracle锁表该如何解决

    这篇文章主要给大家介绍了关于oracle锁表如何解决的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2020-11-11
  • Oracle中sys和system的区别小结

    Oracle中sys和system的区别小结

    SYS用户具有DBA权限,并且拥有SYS模式,只能通过SYSDBA登陆数据库。是Oracle数据库中权限最高的帐号 SYSTEM具有DBA权限。但没有SYSDBA权限。平常一般用该帐号管理数据库就可以了。
    2009-11-11
  • 浅谈Oracle 11g 发行版2 新安装后关于登录的一些基本操作

    浅谈Oracle 11g 发行版2 新安装后关于登录的一些基本操作

    oracle 11g的两个不同版本。11g刚发行时,是11g第一版,简称11.1,现在有个11g第二版,在功能上有了更多的改进,简称11.2。本文给大家介绍Oracle 11g 发行版2 新安装后关于登录的一些基本操作,需要的朋友可以参考下
    2015-10-10
  • oracle中schema指的是什么意思

    oracle中schema指的是什么意思

    看来有的人还是对schema的真正含义不太理解,现在我再次整理了一下,需要的朋友参考下
    2017-03-03
  • Oracle 区块链表创建过程详解

    Oracle 区块链表创建过程详解

    Oracle 区块链表是一个具有防篡改功能的表,只能插入数据,同时提供了表级和行级的保留期限,接下来通过本文给大家分享Oracle区块链平台的创建过程,感兴趣的朋友一起看看吧
    2021-05-05

最新评论