Mybatis批量数据插入

本文介绍了一个使用Spring Boot的控制器类,用于批量插入用户数据到数据库的方法。通过UserController类的insertBatch方法,可以接收一个用户数据对象列表,并调用UserDOMapper接口的insertBatch方法将这些数据批量插入到数据库中。在XML配置文件中,定义了插入数据的SQL语句,使用foreach循环遍历列表并插入每条记录。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Controller

/**
 * @ClassName: UserController
 * @Description: 
 * @Author: xuezhouyi
 * @Version: V1.0
 **/

@RestController
@RequestMapping("/user")
public class UserController {

    @Autowired
    private UserDOMapper userDOMapper;

    @PostMapping("/insertBatch")
    public void insertBatch(@RequestBody List<UserDO> userDOS){
        userDOMapper.insertBatch(userDOS);
    }

}

Dao

/**
 * @ClassName: UserDOMapper
 * @Description: 
 * @Author: xuezhouyi
 * @Version: V1.0
 **/
public interface UserDOMapper {

    void insertBatch(List<UserDO> userDOS);
    
}

XML

<insert id="insertBatch" useGeneratedKeys="true" keyProperty="id"
		parameterType="com.springcloud.dataobject.ds1.UserDO">
	INSERT INTO user(id, name, tel) VALUES
	<foreach collection="list" item="user" index="index" separator=",">
		(#{user.id,jdbcType=BIGINT}, #{user.name,jdbcType=VARCHAR}, #{user.tel,jdbcType=VARCHAR})
	</foreach>
</insert>

DataObject

/**
 * @ClassName: UserDO
 * @Description: 
 * @Author: xuezhouyi
 * @Version: V1.0
 **/
@Data
public class UserDO {
    
    private Integer id;

    private String name;

    private String tel;

}

测试

2019-11-18 13:40:39.056 DEBUG 9932 --- [nio-9090-exec-3] c.i.s.dao.ds1.UserDOMapper.insertBatch   : ==>  Preparing: INSERT INTO user(id, name, tel) VALUES (?, ?, ?) , (?, ?, ?) , (?, ?, ?) 
2019-11-18 13:40:39.075 DEBUG 9932 --- [nio-9090-exec-3] c.i.s.dao.ds1.UserDOMapper.insertBatch   : ==> Parameters: 91(Integer), xavier(String), 111(String), 92(Integer), xavier(String), 111(String), 93(Integer), xavier(String), 111(String)
2019-11-18 13:40:39.083 DEBUG 9932 --- [nio-9090-exec-3] c.i.s.dao.ds1.UserDOMapper.insertBatch   : <==    Updates: 3

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值