mybatis 批量insert 返回主键(实例)

转:

https://www.jianshu.com/p/be01aa549fdd

 

mybatis 批量insert 返回主键(实例)

96 狗尾巴草也开花 关注

2017.07.30 23:16* 字数 88 阅读 949评论 0喜欢 1

时刻记得:不忘初心,方得始终

功能

实现批量插入,并且返回自增id、随机id、uuid等。随你用什么策略。

话不多说,上实例

  • bean
public class UserInfo
{
    private int userId;
    private String userName;
    private StringuserPwd;
    ```(get、set方法)    
}
  • Dao
public interface UserDao{
  int insertBatch(List<UserInfo> userList);
}
  • mapper
<insert id="insertBatch" parameterType="java.util.List" useGeneratedKeys="true" keyProperty="userId">
  insert into user_info
  (
    user_id,
    user_name,
    user_pwd
   )
   values 
  <foreach collection="list" item="item" index="index" separator=","> 
   (     
    null,
    #{item.userName,jdbcType=VARCHAR},
    #{item.userPwd,jdbcType=VARCHAR}
   ) 
   </foreach> 
 </insert>
  • serviceImpl
public List<UserInfo> saveCheckin(List<UserInfo> userList) {
  userDao.insertCheckin(userList); //成功后对象userList里面已经包含主键user_id
  return userList;
}

注意

要将mybatis升到3.3.1以上
不要在Dao 层加@Param注解,不然会被报如下错误

报错:Parameter '你的@Param参数' not found. Available parameters are [list]

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值