zoukankan      html  css  js  c++  java
  • 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是实体类中对应的字段名称

  • 相关阅读:
    Lightoj 1422
    BZOJ 1801 [AHOI 2009] 中国象棋(DP)
    [SCOI2008]天平
    [SCOI2008]奖励关
    [USACO08JAN]haybale猜测Haybale Guessing
    [Sdoi2016]征途
    [SHOI2014]概率充电器
    [USACO08JAN]电话线Telephone Lines
    [HEOI2016]排序
    友好的生物
  • 原文地址:https://www.cnblogs.com/dwtfukgv/p/14208781.html
Copyright © 2011-2022 走看看