Mybatis批量数据插入

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、付费专栏及课程。

余额充值