Mybatis批量插入总结

85 篇文章 0 订阅
13 篇文章 0 订阅

<一>

mybatis中,批量保存的两种方式

          1.使用mybatis foreach标签

          2.mybatis ExecutorType.BATCH

一:使用mybatis foreach标签

具体用法如下:

  <!-- 批量保存(foreach插入多条数据两种方法)
       int addEmpsBatch(@Param("emps") List<Employee> emps); -->
     <!-- MySQL下批量保存,可以foreach遍历 mysql支持values(),(),()语法 --> //推荐使用
     <insert id="addEmpsBatch">
      INSERT INTO emp(ename,gender,email,did)
      VALUES
      <foreach collection="emps" item="emp" separator=",">
      (#{emp.eName},#{emp.gender},#{emp.email},#{emp.dept.id})
      </foreach>
     </insert>

若报错信息为 : Parameter 'list' not found. Available parameters are [lines, param1] , 

1、’即Mapper中方法入参为list集合时, 不需要 @Param(value="")

2、collection="emps" 错误,    collection="list" (这里是固定的)

两种方式详细参考博客: https://www.cnblogs.com/shuaifing/p/9327465.html

foreach 标签属性可参考博客: https://www.cnblogs.com/liaojie970/p/5577018.html

<二>

大数据量的插入与性能问题

参考博客: 

https://blog.csdn.net/syy_c_j/article/details/52151402
https://blog.csdn.net/wlwlwlwl015/article/details/50246717#comments       

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 可以使用 MyBatis 提供的批量插入功能,使用 sqlSession 的 batch 方法,将多个插入操作放在同一个批次中执行,可以提高插入效率。具体实现可以参考 MyBatis 官方文档中的示例代码。 ### 回答2: MyBatis是一种开源的持久层框架,可以与Java程序进行交互,并支持数据库操作。在MyBatis中进行批量插入操作可以提高数据库的性能和效率。下面是一个使用MyBatis进行批量插入的示例代码: 首先,需要在数据库配置文件中配置数据源和映射文件,确保与数据库连接的正常。 其次,创建一个数据访问层接口,如UserMapper。在该接口中定义批量插入方法,如insertBatch,该方法接收一个用户列表作为参数: ```java public interface UserMapper { void insertBatch(List<User> userList); } ``` 然后,在映射文件UserMapper.xml中编写对应的SQL语句: ```xml <insert id="insertBatch" parameterType="java.util.List"> INSERT INTO user (id, name) VALUES <foreach collection="list" item="user" index="index" separator=","> (#{user.id}, #{user.name}) </foreach> </insert> ``` 在该SQL语句中,使用了MyBatis的foreach标签来遍历用户列表,并将每个用户的id和name插入数据库表user中。 最后,需要在Service层或者其他调用层中调用UserMapper接口中的insertBatch方法: ```java public class UserService { private SqlSessionFactory sqlSessionFactory; public void insertUserBatch(List<User> userList) { SqlSession sqlSession = sqlSessionFactory.openSession(); try { UserMapper userMapper = sqlSession.getMapper(UserMapper.class); userMapper.insertBatch(userList); sqlSession.commit(); // 提交事务 } finally { sqlSession.close(); // 关闭SqlSession } } } ``` 在这个示例中,首先获取SqlSession对象,然后通过getMapper方法获取UserMapper接口的实现类,进而调用insertBatch方法,最后提交事务并关闭SqlSession。 通过以上步骤,就可以实现使用MyBatis进行批量插入操作。这样,可以大大提高数据库的插入性能和效率。 ### 回答3: Mybatis是一个用于Java编程语言的持久层框架,可以提供简化数据库访问的方式。在使用Mybatis进行批量插入时,我们可以按照以下步骤进行操作: 1. 配置批量插入的SQL语句:在Mapper文件中,我们可以编写插入语句的SQL语句,并使用foreach标签来循环插入多条数据。 2. 创建Mapper接口:在Java代码中,我们需要创建Mapper接口,用于调用SQL语句。 3. 编写插入方法:在Mapper接口中,我们可以编写一个批量插入的方法,方法名可以自定义,参数可以传入一个包含要插入数据的集合。 4. 实现插入逻辑:在Mapper.xml文件中,对于批量插入的方法,我们需要使用foreach标签,来循环插入集合中的每一条数据。 5. 调用插入方法:在使用批量插入功能时,我们可以在Java代码中,调用Mapper接口中的相应方法。 总结而言,使用Mybatis进行批量插入时,我们需要在配置文件中编写SQL语句,并且在Java代码中创建Mapper接口和实现对应的方法,通过调用该方法来完成批量插入。注意,在进行批量插入时,我们需要合理使用Mybatis的foreach标签,来循环插入每一条数据,以提高插入效率。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值