首先设置属性:useGeneratedKeys,keyProperty

useGeneratedKeys:(仅适用于 insert 和 update)这会令 MyBatis 使用 JDBC 的 getGeneratedKeys 
	方法来取出由数据库内部生成的主键。
	(比如:像 MySQL 和 SQL Server 这样的关系型数据库管理系统的自动递增字段),默认值:false。
keyProperty:(仅适用于 insert 和 update)指定能够唯一识别对象的属性。
	MyBatis 会使用 getGeneratedKeys 的返回值或 insert 语句的 selectKey 子元素设置它的值,
	默认值:未设置(unset)。如果生成列不止一个,可以用逗号分隔多个属性名称。

我的使用:

    int addCustomizedData(@Param("a") Integer a, @Param("b") Integer b, @Param("list") List<Bean> list);

<insert id="addCustomizedData" useGeneratedKeys="true" keyProperty="list.id">
        INSERT INTO tbl_ext (
            name, 
            age
            ) VALUES
        <foreach collection="list" item="item" index="index" separator=",">
            <trim prefix=" (" suffix=")" suffixOverrides=",">
                #{name}, 
                #{age}
            </trim>
        </foreach>
    </insert>
注意:keyProperty="list.id"。id为list中对象中的id属性。我定义的mapper中有多个参数,如果只指定id的话,会报错。
如果只有一个list参数,那直接使用keyProperty="id" 也是可以。

更多推荐

Mybatis批量插入并且返回对应的ID