Mybatis批量insert 返回主键

Mybatis从3.3.1版本开始,支持批量插入后返回主键ID。首先对于支持自增主键的数据库使用useGenerateKeys和keyProperty,对于不支持生成自增主键的数据库使用selectKey标签。类似《MyBatis 返回insert操作主键》中单条插入。

使用批量插入,可以减少和数据库交互的次数,但是,数据量应该做一个控制,和for循环类似。首先定义Java Bean Instance:

import java.io.Serializable;

/**

* 实例表实体类

*/

public class Instance implements Serializable {

private static final long serialVersionUID = 2288066394131442938L;

private Long instanceId;

private String infos;

private String createTime;

private String updateTime;

// omit getter, setter and toString()

}

DAO层:

int addInstances(List<Instance> instanceDtos);

函数返回值是int类型,表示影响的行数。mapper中SQL写法类似于执行单条insert操作,只是使用了foreach标签:

<insert id="addInstances" parameterType="list" useGeneratedKeys="true" keyProperty="instanceId">

insert into instance (infos,create_time,update_time)

values

<foreach collection="list" item="myEg" index="index" separator=",">

(#{myEg.infos},now(),now())

</foreach>

</insert>

执行后,自增长的id都可以从instanceDtos中找到。由于myEg对应于Java对象,所以,读取其中的infos属性时,需要使用myEg.infos。

MyBatis foreach标签详解

下面梳理一下foreach标签。foreach主要用于构建in条件,它可以在SQL语句中迭代入参List或者Array。属性主要有 item,index,collection,open,separator,close,解释如下:

item表示集合中每一个元素进行迭代时的别名,便于在foreach中使用;

index指定一个名字,用于标志当前迭代位置;

open表示该语句以什么开始,如拼凑in子语句的左括号“(”;

separator分隔符,表示每次迭代之间以什么符号分隔;

close表示以什么结束,如拼凑in子语句的右括号“)”。

在所有属性中,最复杂非collection属性莫属,该属性在foreach标签中必须指定的。在不同情况下,该属性的值是不一样的,主要有以下3种情况:

1.若传入的是单参数且参数类型是List,则collection属性值为list;

2.若传入的是单参数且参数类型是Array数组,则collection的属性值为array;

3.若传入的参数是多个,则把它们封装成Map,当然单参数也可以封装成Map,collection的属性值为Map中的key;

上一节中,addInstances函数的入参只有一个,且是List,所以,collection属性值为list。如下函数

List<Instance> getInstanceInfo(new Long[]{1L, 3L});

请求的时候,SQL如下:

<select id="getInstanceInfo" resultType="list">

SELECT instance_id "instanceId", infos

FROM instance

WHERE instance_id IN

<foreach item="oneId" index="index" collection="array"

open="(" separator="," close=")" >

#{oneId}

</foreach>

</select>

oneId表示一个具体的元素,所以,用#{oneId}直接读取就行。

Mybatis批量insert 返回主键值和foreach标签详解的更多相关文章

  1. mybatis添加数据时返回主键 insert 返回主键值

    insert 返回主键值 useGeneratedKeys=“true” parameterType=“USer” keyProperty=“id”, <insert id="inse ...

  2. mybatis 批量插入 返回主键id

    我们都知道Mybatis在插入单条数据的时候有两种方式返回自增主键: 1.对于支持生成自增主键的数据库:增加 useGenerateKeys和keyProperty ,<insert>标签 ...

  3. mybatis mysql 批量insert 返回主键

    Mybatis在插入单条数据的时候有两种方式返回自增主键:    mybatis3.3.1支持批量插入后返回主键ID, 首先对于支持自增主键的数据库:useGenerateKeys和keyProper ...

  4. mybatis批量插入返回主键问题

    今天整合mybatis时候用到返回主键问题,批量插入总是返回不了主键还报错. 记录入下: pom版本: <mybatis.version>3.2.6</mybatis.version ...

  5. Mybatis中insert返回主键ID

    记录解决的过程,这里就不搬砖了. 1.获取insert后的主键id 原文链接:http://www.cnblogs.com/fsjohnhuang/p/4078659.html 2.insert后返回 ...

  6. MyBatis插入语句返回主键值

    插入语句xml代码: <insert id="insertUser" parameterType="com.spring.mybatis.po.User" ...

  7. mybatis.net insert 返回主键

    mybatis insert语句 <insert id="Add" parameterClass="UserInfo" resultClass=" ...

  8. mybatis的insert返回主键

    <insert id="insert" useGeneratedKeys="true" keyProperty="id" parame ...

  9. mybatis 08: 返回主键值的insert操作 + 利用UUID获取字符串(了解)

    返回主键值的insert操作 应用背景 图示说明 在上述业务背景下,涉及两张数据表的关联操作:用户表 + 用户积分表 传统操作:在对用户表执行完插入语句后,再次查询该用户的uid,将该uid作为外键, ...

随机推荐

  1. .NET实现事务的编码方式

    1,在T-SQL语句中用begin tran,end tran的方式 begin tran --select top(1) * from dbo.test with(updlock) update t ...

  2. Java知多少(6)第一个程序示例

    跟随世界潮流,第一个Java程序输出“Hell World!”. 通过Eclipse运行程序 启动Eclipse,在菜单中选择“文件 --> 新建 --> Java项目”,弹出对话框: 图 ...

  3. Why you should use async tasks in .NET 4.5 and Entity Framework 6

    Improve response times and handle more users with parallel processing Building a web application usi ...

  4. Numpy 定义矩阵的方法

    import numpy as np #https://www.cnblogs.com/xzcfightingup/p/7598293.html a = np.zeros((2,3),dtype=in ...

  5. centos6.5安装mongodb2.6

    下载地址:http://www.mongodb.org/downloads 解压命令:tar zxf mongodb-linux-i686-2.6.0.tgz 存放目录:/usr/local/mong ...

  6. SpringBoot(三)整合Redis

    spring boot对常用的数据库支持外,对nosql 数据库也进行了封装自动化. redis介绍 Redis是目前业界使用最广泛的内存数据存储.相比memcached,Redis支持更丰富的数据结 ...

  7. eclipse安装emmet插件

    http://www.cnblogs.com/matchless/archive/2013/04/10/3011973.html

  8. 3、一、Introduction(入门):2、Device Compatibility(设备兼容性)

    2.Device Compatibility(设备兼容性)   Android is designed to run on many different types of devices, from ...

  9. akka cluster singleton

    cluster singleton 需要注意的一点是 ClusterSingletonProxy 必须和 ClusterSingletonManager 一起工作 尝试过通过 path 来获得 sin ...

  10. python 读取配置文件方法

    #coding=utf8 import ConfigParser config = ConfigParser.ConfigParser() config.readfp(open(raw_input(& ...