MybatisBatchUtils功能介绍

MybatisBatchUtils 是一个 MyBatis 框架的工具类,主要用于简化 MyBatis 中批量操作的代码编写。该工具类封装了 MyBatis 中的批量操作方法,可以方便地进行批量插入、更新和删除等操作。

一般来说,使用 MyBatis 进行批量操作需要先设置 JDBC 驱动的批量处理模式,然后调用 MyBatis 提供的批量操作 API 执行相应的 SQL 语句。这个过程比较繁琐,需要自己手动编写大量的代码。而 MybatisBatchUtils 工具类则为我们提供了更加便捷的方式,可以帮助我们快速完成批量操作。

MybatisBatchUtils 工具类中提供了以下常用方法:

  • 批量插入:

    • batchInsert(String statement, List<Object> objects):批量插入操作,参数包括要执行的SQL语句和待插入的对象列表。
  • 批量更新:

    • batchUpdate(String statement, List<Object> objects):批量更新操作,参数包括要执行的SQL语句和待更新的对象列表。
  • 批量删除:

    • batchDelete(String statement, List<Object> objects):批量删除操作,参数包括要执行的SQL语句和待删除的对象列表。
  • 批量操作的返回结果:

    • BatchResult对象:该对象用于保存批量操作的结果信息,包括成功执行的记录数、失败执行的记录数等。

这些方法都封装了 MyBatis 中的批量操作 API,使用起来非常方便。例如,要批量插入多条记录到数据库中,只需要将记录封装成一个 List,然后调用 insertBatch() 方法即可,无需手动拼接 SQL 语句或者设置 JDBC 驱动的批量处理模式等操作。

总的来说,MybatisBatchUtils 工具类可以帮助我们简化 MyBatis 中批量操作的代码编写,提高开发效率,减少出错的可能性。

之前一直用MyBatis-Plus 中的IService, 它 是一个基础的 Service 接口,它提供了常用的 CRUD(增删改查)操作方法包括一些批量操作,以及一些简单的条件查询和分页查询方法。IService 接口定义了常见的数据库操作,包括插入、更新、删除和查询等。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis-plus提供了方便的批量修改功能,但官方提供的批量修改方法是根据id来进行修改的。如果我们需要根据其他字段进行批量修改,我们可以自己进行修改。可以参考以下方法实现在Mybatis环境下的批量修改: 1. 创建一个工具类,例如MybatisBatchUtils,使用@Component注解标注为组件,确保可以被Spring容器管理。 2. 在MybatisBatchUtils类中,注入SqlSessionFactory,这样我们就可以使用Mybatis功能。 3. 编写一个公共的批量修改方法batchUpdateOrInsert,该方法接受三个参数:data(待修改的数据列表)、mapperClass(映射器的Class对象)、function(接收两个参数,并返回结果的函数)。 4. 在batchUpdateOrInsert方法中,定义一个常量BATCH_SIZE表示批处理的大小,可以根据需要进行调整。 5. 打开一个批处理的SqlSession,通过sqlSessionFactory.openSession方法来获取。 6. 获取对应的映射器对象mapper,通过batchSqlSession.getMapper(mapperClass)方法来获取。 7. 遍历待修改的数据列表data,对每个元素调用function.apply方法来进行修改操作。如果达到批处理大小或者遍历到最后一个元素时,调用batchSqlSession.flushStatements方法来执行批处理SQL。 8. 在非事务环境下,使用batchSqlSession.commit方法来提交事务。 9. 如果在修改过程中发生异常,调用batchSqlSession.rollback方法来回滚事务,并抛出异常。 10. 最后,关闭批处理的SqlSession,通过batchSqlSession.close()方法来关闭。 这样,我们就可以使用Mybatis-plus实现批量修改的需求了。这种方法可以避免使用foreach循环对每条数据进行修改,提高了性能并减少了代码量。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [Mybatis-plus批量操作](https://blog.csdn.net/WayneLee0809/article/details/126424482)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值