oracle设置mybatis自动生成id插入

本来想要在插入时自动生成id是很简单的,就是用mybatisPlus的注解,在实体类的id字段上加上@TableId注解,自动生成由雪花算法生成的id,不但随机,而且自增,非常好用

但是现在接手了一个项目没有导入mybaitisPlus,只有mybatis,我不敢乱加东西,只能用mybatis做主键自增了

首先这是一个oracle数据库,和mysql不同,Oracle不能设置自增,只能先创建一个序列(sequence),然后在插入数据时引用该序列的值,原sql如下:

insert into table_name (ID, name, sex)  
values (sequence_name.NEXTVAL,'张三','男')  

 我们从头开始,在创建序列之前,先查询一下已有序列

SELECT * from user_sequences

 创建序列

CREATE sequence sequence_name
increment by 1 //以1倍的速度增长,你也可以设置其他数字
start with 1    //从id=1开始增长  
 maxvalue 9999  //最大值为9999,根据情况  
 minvalue 1     //最小值1  
 nocycle        //不循环,也就是一直增长         
 cache 20       //设置缓存cache个序列,如果系统down掉了或者其它情况将会导致序列不连续,也可以设置为---------NOCACHE  
noorder;

mybatis中代码:

<insert id="insertAccessLog" parameterType="com.example.AccessLog">
        <selectKey keyProperty="id" resultType="java.lang.Integer" order="BEFORE">
            SELECT YOUR_SEQUENCE_NAME.NEXTVAL FROM DUAL
        </selectKey>
        INSERT INTO your_table_name (ID, name,sex)
        VALUES (#{id}, #{name}, #{sex})
    </insert>

selectKey标签可以在插入语句执行前执行一个查询,以生成主键值。以下是selectKey标签的常用属性:

  1. keyProperty:指定一个Java对象的属性,用于接收生成的主键值。生成的主键值将被设置到该属性中。

  2. keyColumn:指定数据库表中的列名,用于接收生成的主键值。生成的主键值将被设置到该列中。

  3. resultType:指定生成的主键值的数据类型。可以是Java中的任何原生类型,如intlong,或者是一个包装类型,如IntegerLong

  4. order:指定selectKey标签的执行顺序。可以选择在插入语句执行前执行(BEFORE)或执行后执行(AFTER)。默认值是AFTER

注意:java实体类属性的类型和数据库字段类型最好一致,否则在插入时会导致插入时类型不匹配

还有一种更简单的写法:

INSERT INTO your_table_name (ID, name,sex)
        VALUES (your_sequence_name, #{name}, #{sex})

下面还有一种情况要注意:

mybatis插入一个list,list里是实体类,实体类本身没有生成id,需要oracle数据库使用sequence生成id,如插入List<userDTO>

本来我们使用foreach标签配合values的写法批量插入的,如下:

insert into PERMANENT_ACCESS_USER (EMPLOYEE_USERACCOUNT,EMPLOYEE_NAME)
            values 
<foreach collection="list" item="item" separator="," close=";">
(#{item.userAccounts},#{item.empName})
</foreach>

或者这样

insert all
        <foreach collection="list" item="item" separator=" ">
            into table_name (name,sex) values ( #{item.name},#{item.sex})
        </foreach>
        SELECT * FROM DUAL

但是现在有个问题,在一个values中只能调用一次NEXTVAL,使得我们没办法在批量插入时给ID赋不同的值

所以现在解决办法是使用触发器,在插入时将序列值赋给id,但是这样的话就需要每张表都要建一个触发器,而触发器又不可控,但是现在又没有找到另外的方法,只能先这样,具体参考:

Oracle sql批量插入多条数据_sql 跟oracle sql insert into多条_cjjiang1536的博客-CSDN博客

或者干脆不用序列,直接生成一个随机数,用随机数当id

注意!!!因为用了inser into。。。select的语法,所以useGeneratedKeys="false"这个一定要加在insert标签里面,否则会报错

这个坑踩了好久,一度误以为mybatis不支持inser into。。。select语法,一定要注意

useGeneratedKeys="false"
<insert id="insertPermanentUser" parameterType="list" useGeneratedKeys="false">
        INSERT INTO PERMANENT_ACCESS_USER(id, name, sex)
        SELECT id, name, sex FROM
        <foreach collection="list" item="item" separator=" union all " open="(" close=")">
            SELECT dbms_random.VALUE(0,10000000) as id,#{item.name} as name,#{item.sex} as sex from dual
        </foreach>
    </insert>

  • 2
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
Oracle数据库使用MyBatis进行高效的百万级批量插入可以使用批处理操作,以下是实现步骤: 1. 配置MyBatis的批处理属性: 在MyBatis的配置文件中添加以下属性: ``` <settings> <setting name="jdbcTypeForNull" value="NULL" /> <setting name="cacheEnabled" value="true" /> <setting name="lazyLoadingEnabled" value="true" /> <setting name="aggressiveLazyLoading" value="false" /> <setting name="multipleResultSetsEnabled" value="true" /> <setting name="useColumnLabel" value="true" /> <setting name="useGeneratedKeys" value="false" /> <setting name="autoMappingBehavior" value="PARTIAL" /> <setting name="autoMappingUnknownColumnBehavior" value="WARNING" /> <setting name="defaultExecutorType" value="SIMPLE" /> <setting name="defaultStatementTimeout" value="25000" /> <setting name="defaultFetchSize" value="100" /> <setting name="safeRowBoundsEnabled" value="false" /> <setting name="mapUnderscoreToCamelCase" value="false" /> <setting name="localCacheScope" value="SESSION" /> <setting name="jdbcTypeForNull" value="NULL" /> <setting name="flushCacheEnabled" value="false"/> <setting name="batch" value="true"/> </settings> ``` 其中,最后一行 `batch` 属性表示开启批处理模式。 2. 编写Mapper文件: 在Mapper文件中编写批量插入的SQL语句,例如: ``` <insert id="batchInsert" parameterType="java.util.List"> insert into user (id, name, age) values <foreach collection="list" item="user" separator=","> (#{user.id}, #{user.name}, #{user.age}) </foreach> </insert> ``` 其中,`parameterType` 指定了传入参数的类型为 `List`,`foreach` 标签表示对传入的List进行遍历,生成批量插入的SQL语句。 3. 编写Java代码: 在Java代码中使用MyBatis的 `SqlSession` 对象执行批量插入操作,示例如下: ``` SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH); UserMapper userMapper = sqlSession.getMapper(UserMapper.class); List<User> userList = new ArrayList<>(); // 添加一百万条测试数据 for (int i = 0; i < 1000000; i++) { User user = new User(); user.setId(i+1); user.setName("user"+i); user.setAge(20+i); userList.add(user); } userMapper.batchInsert(userList); sqlSession.commit(); ``` 其中,`SqlSessionFactory` 是MyBatis的会话工厂对象,`UserMapper` 是Mapper接口对象,`userList` 是需要批量插入的数据列表,最后需要调用 `commit()` 方法提交事务。 这样,就可以使用MyBatis进行高效的百万级批量插入操作了。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值