Mybatis 插入一条或批量插入 返回带有自增长主键记录的实例
2017-12-14 13:59
721 查看
首先讲一下, 插入一条记录返回主键的 Mybatis 版本要求低点,而批量插入返回带主键的 需要升级到3.3.1版本,3.3.0之前的都不行。
<dependency> <groupId>org.mybatis</groupId> <artifactId>mybatis-spring</artifactId> <version>3.3.1</version> </dependency>
1.MySQL
<insert id="insertByBatch" useGeneratedKeys="true" keyProperty="id" parameterType="java.util.List"> insert into test (sblsh, xh, jsjg, is_success, is_display, gmt_create, gmt_modify, create_user) values <foreach collection="list" item="item" index="index" separator=","> ( #{item.sblsh,jdbcType=BIGINT}, #{item.xh,jdbcType=CHAR}, #{item.jsjg,jdbcType=BIGINT}, #{item.isSuccess,jdbcType=TINYINT}, #{item.isDisplay,jdbcType=TINYINT}, SYSDATE(), SYSDATE(), #{item.createUser,jdbcType=VARCHAR}) </foreach> </insert>
单条和多条 使用都是一样的, 加入useGeneratedKeys="true" keyProperty="主键字段"
2.Oracle
<insert id="insertBatch"> <selectKey keyProperty="id" resultType="Long" order="BEFORE"> select test.nextval as id from dual </selectKey> insert into test (id,value,gmt_create,gmt_modified) select test.nextval, A.* FROM ( <foreach collection="list" item="item" index="index" separator="union all"> select #{item.value,jdbcType=VARCHAR}, #{item.gmtCreate,jdbcType=DATE}, #{item.gmtModified,jdbcType=DATE} from dual </foreach> ) A </insert>
以上这篇Mybatis 插入一条或批量插入 返回带有自增长主键记录的实例就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。
您可能感兴趣的文章:
相关文章推荐
- 使用Mybatis时,在插入一条数据记录返回主键id值
- mybatis插入一条记录,返回自增主键值
- MyBatis+MySQL 返回插入记录的主键ID
- Java--批量插入更新在一条sql里解决-mybatis-mysql-联合主键(建立唯一索引)
- Mybatis插入一条数据后返回刚插入数据主键
- MyBatis魔法堂:Insert操作详解(返回主键、批量插入)
- MyBatis:Insert操作详解(返回主键、批量插入)
- MyBatis魔法堂:Insert操作详解(返回主键、批量插入)
- mybatis插入一条记录如何返回该记录的ID
- mysql实现插入一条记录时候还回主键值,表的主键是自增长方式AUTO_INCREMENT
- mybatis insert多级List级联类 之(批量插入返回主键集合)使用《示例》下
- mybatis 插入时返回刚插入记录的主键值
- MyBatis魔法堂:Insert操作详解(返回主键、批量插入)
- MyBatis魔法堂:Insert操作详解(返回主键、批量插入)
- Mybatis 批量插入返回 主键ID
- MyBatis魔法堂:Insert操作详解(返回主键、批量插入)
- mybatis插入记录后返回主键
- MyBatis :Insert (返回主键、批量插入)
- Mybatis之Insert操作详解(返回主键、批量插入)
- mybatis进行批量插入 返回批量插入主键ID 插入不成功等问题