oracle中取top10,Oracle结合Mybatis实现取表TOP 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 *

from(select rownum rn, A.* fromstudent Awhere STATUS = ‘99‘

and score ]]> #{scores,jdbcType=INTEGER})where rn #{number,jdbcType=INTEGER}

上面的scores和number均为变量

碎碎念一般的写了这么点。希望能帮助一下遇到和我相同问题的朋友。

Oracle结合Mybatis实现取表TOP 10

标签:实现   informix   和我   使用   rac   mys   jdb   blog   orm

本条技术文章来源于互联网,如果无意侵犯您的权益请点击此处反馈版权投诉 本文系统来源:http://www.cnblogs.com/cfyrwang/p/7775142.html

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在使用MyBatis操作Oracle数据库时,Oracle默认的自增长字段是通过序列(Sequence)实现的。要在自定义实现自增,可以通过以下步骤实现: 1. 创建一个序列: 在Oracle数据库,可以使用CREATE SEQUENCE语句创建一个序列。例如创建一个名为custom_table_seq的序列,步长为1,起始值为1: ``` CREATE SEQUENCE custom_table_seq START WITH 1 INCREMENT BY 1; ``` 2. 在自定义添加一个数值类型的字段作为自增字段: 在自定义添加一个名为id的数值类型字段,用来保存自增的值。 ``` ALTER TABLE custom_table ADD id NUMBER(10); ``` 3. 在MyBatis的Mapper XML文件配置插入语句: 在Mapper XML文件,可以使用SELECT LAST_INSERT_ID()函数获得自增的值,并将其插入到自定义的id字段。 ``` <insert id="insertCustomTable" parameterType="CustomTable"> <selectKey keyProperty="id" order="BEFORE" resultType="java.lang.Long"> SELECT custom_table_seq.NEXTVAL FROM DUAL </selectKey> INSERT INTO custom_table (id, column1, column2) VALUES (#{id}, #{column1}, #{column2}) </insert> ``` 上述代码,selectKey标签用于获序列的下一个值,并将其设置到id属性上。 需要注意的是,在使用Generator类生成的实体类,需要添加相应的属性和getter、setter方法。同时,还需要在DAO接口定义插入方法。 ``` public void insertCustomTable(CustomTable customTable); ``` 通过以上步骤,便可以在自定义实现自增功能。每次插入数据时,自定义的id字段都会自动增加,并保持唯一。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值