首先设置属性: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" 也是可以。