数据库------MyBatis 使用 foreach 批量插入

博客介绍了MyBatis使用foreach进行批量插入的两种方式。一是单条语句插入多个值,需修改Mapper添加方法、修改映射文件添加语句并测试接口;二是多条语句插入多个值,除上述操作外,还需修改jdbcUrl允许执行多条语句,最后提及了可能存在的bugs。
部署运行你感兴趣的模型镜像

MyBatis 使用 foreach 批量插入

  1. 第1种方式 单条语句插入多个值

修改 Mapper 添加批量插入方法

@Mapper
public interface UserMapper {
    void batchSave(List<User> userList);
}

修改映射文件 添加批量插入映射语句

<insert id="batchSave">
    insert into user(name, password) values
    <foreach collection="list" item="user" separator=",">
        (#{user.name}, #{user.password})
    </foreach>
</insert>

测试接口

@RunWith(SpringRunner.class)
@SpringBootTest
public class SbMybatis02ApplicationTests {
    @Test
    public void testBatchSave(){
        User user1 = new User();
        user1.setName("关羽");
        user1.setPassword("guanyu");
        User user2 = new User();
        user2.setName("张飞");
        user2.setPassword("zhangfei");
        List<User> userList  = new ArrayList<>();
        userList.add(user1);
        userList.add(user2);

        userMapper.batchSave(userList);
    }
}
  1. 第2种方式 多条语句插入多个值

修改 Mapper 添加批量插入方法

@Mapper
public interface UserMapper {
    void batchSave(List<User> userList);
}

修改映射文件 添加批量插入映射语句

<insert id="batchSave">
    <foreach collection="list" item="user" separator=";">
        insert into user(name, password) values
        (#{user.name}, #{user.password})
    </foreach>
</insert>

修改 jdbcUrl 允许执行多条语句

jdbc:mysql://localhost:3306/db3?serverTimezone=Asia/Shanghai&allowMultiQueries=true

测试接口

@RunWith(SpringRunner.class)
@SpringBootTest
public class SbMybatis02ApplicationTests {
    @Test
    public void testBatchSave(){
        User user1 = new User();
        user1.setName("关羽");
        user1.setPassword("guanyu");
        User user2 = new User();
        user2.setName("张飞");
        user2.setPassword("zhangfei");
        List<User> userList  = new ArrayList<>();
        userList.add(user1);
        userList.add(user2);

        userMapper.batchSave(userList);
    }
}
  1. bugs
Caused by: java.sql.SQLSyntaxErrorException: You have an error in your SQL syntax; check the manual that corresponds to your MySQL server version for the right syntax to use near 'insert into user(name, password) values('张飞', 'zhangfei')' at line 4
方案:
	jdbcUrl 添加参数 allowMultiQueries=true

您可能感兴趣的与本文相关的镜像

ACE-Step

ACE-Step

音乐合成
ACE-Step

ACE-Step是由中国团队阶跃星辰(StepFun)与ACE Studio联手打造的开源音乐生成模型。 它拥有3.5B参数量,支持快速高质量生成、强可控性和易于拓展的特点。 最厉害的是,它可以生成多种语言的歌曲,包括但不限于中文、英文、日文等19种语言

MyBatis-Plus 提供了多种方式来实现批量插入操作,以提高数据插入的效率并减少对数据库的压力。以下是几种常见的实现方法: ### 1. 使用 `saveBatch` 方法 MyBatis-Plus 提供了一个内置的方法 `saveBatch`,可以用于批量插入数据。这个方法的基本用法如下: ```java List<User> userList = new ArrayList<>(); // 添加多个 User 对象到 userList 中 userServiceImpl.saveBatch(userList); ``` 需要注意的是,`saveBatch` 实际上是通过一个 for 循环逐条插入数据,这可能会对数据库造成较大的压力[^2]。 ### 2. 手写 SQL 实现批量插入 为了提高性能,可以通过编写自定义的 SQL 语句来实现更高效的批量插入。例如,可以使用如下的 SQL 语句: ```sql INSERT INTO test (a, b, c) VALUES <foreach collection="list" item="item" separator=","> (#{item.a}, #{item.b}, #{item.c}) </foreach> ``` 在 MyBatis 的 XML 映射文件中,可以这样使用: ```xml <insert id="batchInsert"> INSERT INTO test (a, b, c) VALUES <foreach collection="list" item="item" separator=","> (#{item.a}, #{item.b}, #{item.c}) </foreach> </insert> ``` 然后,在 Java 代码中调用该方法: ```java List<User> userList = new ArrayList<>(); // 添加多个 User 对象到 userList 中 userMapper.batchInsert(userList); ``` 这种方法通过一次性的 SQL 插入多条记录,减少了与数据库的交互次数,从而提高了性能[^2]。 ### 3. 使用 `InsertBatchSomeColumn` 插件 除了上述方法外,还可以利用一些第三方插件或者自定义插件来优化批量插入操作。例如,`InsertBatchSomeColumn` 插件可以帮助简化批量插入的过程。具体配置和使用方法可以根据插件文档进行设置。 #### 配置类 `MybatisPlusConfig` ```java @Configuration public class MybatisPlusConfig { @Bean public MyInterceptor myInterceptor() { return new MyInterceptor(); } } ``` #### 实体类 `User` ```java @Data public class User { private Long id; private String name; private Integer age; private String email; } ``` #### Mapper 接口 `UserMapper` ```java public interface UserMapper extends BaseMapper<User> { void insertBatchSomeColumn(@Param("list") List<User> list); } ``` #### 测试类 `InsertBatchTest` ```java @SpringBootTest public class InsertBatchTest { @Autowired private UserMapper userMapper; @Test public void testInsertBatchSomeColumn() { List<User> userList = new ArrayList<>(); // 初始化 userList 数据 userMapper.insertBatchSomeColumn(userList); } } ``` 通过这些方法,可以有效地提高 MyBatis-Plus 在处理大量数据插入时的性能和效率。
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值