mybatis中Oracle数据库如何实现主键自增

    我们在使用mybatis框架进行数据库插入操作时,经常会遇到主键自增的问题!MySQL和SQLserver本身就提供了主键自增的功能,所以我们用起来很方便,但是Oracle没有直接提供主键自增功能,这个时候我们可以通过下面几种方式实现主键自增效果:


1.单独插入一条数据(两种方式)
  
  第一种:每次都会从数据库里查一遍,从最大值+1
    <selectKey keyProperty="userId" resultType="String" order="BEFORE">
         select max(USER_ID)+1 from SYS_USER
    </selectKey>

  第二种:Oracle提供了序列功能,创建一个sequences,sequences每次会从上一次基础上+1
    <selectKey keyProperty="userId" resultType="String" order="BEFORE">
         SELECT SEQ_SYS_USER.NEXTVAL FROM DUAL
    </selectKey>

2.批量插入数据
    因为mybatis批量操作需要循环,没办法用上面的方法循环自增,这时候我们可以通过触发器实现id自增!

创建一个触发器(Triggers)
create or replace trigger INSERT_PRIMARY
  before insert
  on SYS_USER 
  for each row
declare
  -- local variables here
  user_id number(16);
begin
  select seq_sys_user.nextval into user_id from dual;
  :new.user_id:=user_id;
end INSERT_PRIMARY;


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值