• 博客园logo
  • 会员
  • 众包
  • 新闻
  • 博问
  • 闪存
  • 赞助商
  • HarmonyOS
  • Chat2DB
    • 搜索
      所有博客
    • 搜索
      当前博客
  • 写随笔 我的博客 短消息 简洁模式
    用户头像
    我的博客 我的园子 账号设置 会员中心 简洁模式 ... 退出登录
    注册 登录
dwtfukgv
博客园    首页    新随笔    联系   管理    订阅  订阅
mybatis 批量插入返回自增ID

如果批量插入需要返回自增ID,需要满足4个条件:

  1. mybatis的版本需要在3.3.1以上
  2. batchInsert方法参数中不能含有@param注解
  3. batchInsert方法参数中只能有一个参数,那就是需要插入的List
  4. batchInsert的返回值不能是List

下面说给出一个例子:

/**
 * @author: dwtfukgv
 * @version: 1.0
 * @date: 2020/12/29 8:42 下午
 */
public interface QuestionDiyMapper {

    /**
     * 批量插入
     * @param list 需要插入的PO
     */
    void batchInsert(List<QuestionPO> list);
}

<insert id="batchInsert"  keyColumn="id" keyProperty="id" parameterType="java.util.List" useGeneratedKeys="true">
  insert into `tb_net_course_question` (
  course_id, description
  ) values
  <foreach collection="list" item="item" separator=",">
    (#{item.courseId,jdbcType=BIGINT}, #{item.description,jdbcType=LONGVARCHAR})
  </foreach>
</insert>

上面的keyColumn是数据库中对应的字段名称,keyProperty是实体类中对应的字段名称

posted on 2020-12-29 21:11  dwtfukgv  阅读(796)  评论(0)    收藏  举报
刷新页面返回顶部
博客园  ©  2004-2025
浙公网安备 33010602011771号 浙ICP备2021040463号-3