您的位置:首页 > 其它

Mybatis 批量插入 返回自增Id

2016-12-02 00:33 337 查看
2月18日,mybatis3.3.1解决了此问题。好开心,省了多余的查询了。

自己测试了一下。

例子表:

CREATE TABLE `user` (
`id` INT NOT NULL AUTO_INCREMENT,
`name` VARCHAR(16) NULL COMMENT '名称',
PRIMARY KEY (`id`));


POM 依赖:

<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis</artifactId>
<version>3.3.1</version>
</dependency>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-spring</artifactId>
<version>1.2.4</version>
</dependency>


XML代码部分:

<insert id="addUserBatch" useGeneratedKeys="true" keyProperty="id">
INSERT INTO user(name)
VALUES
<foreach collection="list" index="index" item="item" open=" " separator="," close=" ">
( #{item.name})
</foreach>
</insert>


注意:入参集合请使用“collection”、“list”或者“array”。

原因查看Mybatis更新记录:

private Collection<Object> getParameters(Object parameter) {
Collection<Object> parameters = null;
if (parameter instanceof Collection) {
parameters = (Collection) parameter;
} else if (parameter instanceof Map) {
Map parameterMap = (Map) parameter;
// when you insert a List(or Array).
// If you want retrieve the auto-increment value or default value.
// You should not to use @Param annotations, You must use a single parameter(List or Array).
if (parameterMap.containsKey("collection")) {
parameters = (Collection) parameterMap.get("collection");
} else if (parameterMap.containsKey("list")) {
parameters = (List) parameterMap.get("list");
} else if (parameterMap.containsKey("array")) {
parameters = Arrays.asList((Object[]) parameterMap.get("array"));
}
}
if (parameters == null) {
parameters = new ArrayList<Object>();
parameters.add(parameter);
}
return parameters;
}
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: