向数据库中插入数据时,大多数情况都会使用自增列或者UUID做为主键。主键的值都是插入之前无法知道的,但很多情况下我们在插入数据后需要使用刚刚插入数据的主键,比如向两张关联表A、B中插入数据(A的主键是B的外键),向A表中插入数据之后,向B表中插入数据时需要用到A的主键。

  比如添加一个用户,同时返回插入用户后得到的用户id:

  1. /** * 添加用户信息 * @param user * @throws Exception */ public int insertUser(User user) throws Exception { SqlSession session=sqlSessionFactory.openSession(); session.insert("com.danny.mybatis.insertUser", user); session.commit(); return user.getUserId();//返回插入数据库后得到的用户id }

  这里总结一下mybatis插入数据时返回主键的4种情况:MySQL环境下主键自增、mysql环境下主键为uuid、mysql环境下主键自增、mysql环境下主键为uuid。

  以下全文均以User实体来举例说明,字段有userId、userName、sex、birthday、address 五个属性,其中userId有可能是int类型,也有可能是String类型。

数据库为mysql


主键为自增时(主键为数值类型且自增)

  利用mysql的LAST_INSERT_ID()方法获取插入记录的主键,select LAST_INSERT_ID()可以在插入数据后,查询并返回刚插入数据的主键(但是单独执行这条语句只会返回0)。

<insert id="insertUser" parameterType="com.danny.mybatis.po.User"> <selectKey keyProperty="userId" order="AFTER" resultType="java.lang.Integer"> select LAST_INSERT_ID() </selectKey> insert into T_USER(userName,birthday,sex,address) values (#{userName},#{birthday},#{sex},#{address}) </insert>

  parameterType:指定insert执行语句接收的参数类型为pojo(这里的user)。

  keyProperty:将查询到的主键值设置到parameterType指定对象的哪个属性。

  order:<selectKey> 标签内的sql语句相对于insert语句的执行顺序,AFTER表示select LAST_INSERT_ID() 这个语句将在insert语句之后执行。

主键为UUID时(主键必须为字符类型)

  使用mysql的方法UUID()方法获取随机的UUID作为主键,select UUID()可以在插入数据前,生成随机的UUID并通过keyProperty赋值给将要插入记录的主键。

<insert id="insertPerson" parameterType="com.danny.mybatis.po.User"><selectKey keyProperty="userId" order="BEFORE" resultType="java.lang.String">select UUID()</selectKey>insert into user(userId,userName,birthday,sex,address) values (#{id},#{userName},#{birthday},#{sex},#{address}) </insert>

  在上述代码中可以看到order 的属性值为BEFORE ,说明在插入之前就已经生成了UUID,并且已经把UUID赋值给user的id。

背 景数据库为oracle:

主键为自增时(主键为数值类型):

  在oracle中实现主键自增,需要先创建序列,相当于创建一个全局变量,用来存储对应表的主键的当前最大值(主键为数值类型时)。

  先为user表创建一个序列:

CREATE SEQUENCE USER_ID_SEQ

INCREMENT BY 1 -- 每次递增1

START WITH 1 -- 从1开始

MINVALUE 1 -- 最小值=1

NOCYCLE; -- 不循环

  利用USER_ID_SEQ.NEXTVAL 获得要插入数据的主键:

<insert id="insertUser" parameterType="com.danny.mybatis.po.User"><selectKey keyProperty="userId" order="BEFORE" resultType="java.lang.Integer"> select USER_ID_SEQ.NEXTVAL as userId from DUAL </selectKey> insert into T_USER(userId,userName,birthday,sex,address) values (#{userId},#{userName},#{birthday},#{sex},#{address}) </insert>

主键为UUID时

  用oracle自带的SYS_GUID()方法获得随机的GUID作为主键:

<insert id="insertUser" parameterType="com.danny.mybatis.po.User"><selectKey keyProperty="userId" order="BEFORE" resultType="java.lang.Integer"> select SYS_GUID() as userId from DUAL </selectKey> insert into T_USER(userId,userName,birthday,sex,address) values (#{userId},#{userName},#{birthday},#{sex},#{address}) </insert>

MyBatis框架——mybatis插入数据返回主键(mysql、oracle)相关推荐

  1. oracle 导入数据时主键丢失,Oracle 插入数据 返回主键

    场景:解决getJdbcTemplate往oracle数据库中插入数据返回主键出错有关问题 解决getJdbcTemplate往oracle数据库中插入数据返回主键出错问题 我们使用Spring中的J ...

  2. mysql插入数据返回主键值_Mysql千万级别数据批量插入只需简单三步!

    第一步:配置my.ini文件 文件中配置 bulk_insert_buffer_size=120M 或者更大 将insert语句的长度设为最大. Max_allowed_packet=1M Net_b ...

  3. mysql插入数据返回主键值_Mysql插入记录后返回该记录ID

    最近和Sobin在做一个精品课程的项目,因为用到一个固定的id作为表间关联,所以在前一个表插入数据后要把插入数据生成的自增id传递给下一个表.研究了一番决定使用Mysql提供了一个LAST_INSER ...

  4. Mybatis-plus向oracle插入数据返回主键

    1.在实体类上指定使用序列 @KeySequence(value = "your seq") //指向当前序列 2.指定自增长字段 @TableId(value = "I ...

  5. MyBatis 插入数据库返回主键

    最近在搞一个电商系统中由于业务需求,需要在插入一条产品信息后返回产品Id,刚开始遇到一些坑,这里做下笔记,以防今后忘记. 类似下面这段代码一样获取插入后的主键 User user = new User ...

  6. Mybatis批量插入,返回主键ID不成功,巨坑

    一.场景说明 批量插入,返回主键ID报错 org.mybatis.spring.MyBatisSystemException: nested exception is org.apache.ibati ...

  7. sql新增数据返回主键

    sql新增数据返回主键 @Options(useGeneratedKeys = true, keyProperty = "id", keyColumn = "id&quo ...

  8. 3、JavaWeb中Service层的作用、MyBatis的重要组件、mybatis-config.xml中的别名映射、properties配置、#{}和${}的区别、获取插入数据的主键值

    文章目录 1.Service层的作用 2.MyBatis重要组件 Resources SqlSessionFactoryBuilder SqlSessionFactory SqlSession 针对上 ...

  9. 2.4.3 Mybatis 高级查询, 复杂映射, 返回主键, 动态SQL if, set, foreach, 核心配置文件深入,plugins标签, 多表查询, 嵌套查询

    目录 Mybatis 复杂映射&配置文件深入 一 Mybatis高级查询 1.1 ResutlMap属性 1.2 多条件查询(三种) 1.3 模糊查询 二 Mybatis映射文件深入 2.1 ...

最新文章

  1. 图像形态学(opencv),运行后通过在屏幕上输入对应指令完成相对应的形态学方法。
  2. 如何清除Git中的本地工作目录? [重复]
  3. C2893 未能使函数模板“unknown-type std::invoke(_Callable ,_Types ...)”专用化 websocket_server
  4. 简单团队-爬虫豆瓣top250-项目总结
  5. java 自定义监听_Spring 中的自定义事件
  6. Python3 数字运算
  7. LeetCode 581. 最短无序连续子数组(排序单调栈)
  8. 计算机配件推荐系统论文摘要,个性化推荐系统设计
  9. MySQL 分页优化中的 “ INNER JOIN方式优化分页算法 ” 到底在什么情况下会生效?
  10. 韩顺平php视频笔记68 析构函数 php垃圾回收机制
  11. java scheduler_RxJava Scheduler介绍
  12. 程序员生涯之我见 找到自己的兴趣所在 (zz)
  13. java指定jre_java 运行应用程序,指定jre版本
  14. 04.如何升级扩展以支持Visual Studio 2019
  15. 625某电商网站数据库宕机故障解决实录(上)
  16. 计算机office基础知识题库,计算机一级MS Office基础考试题库
  17. vue+eleme upload 上传图片(含gif动图) canvas压缩,base64转blob对象
  18. 小学校本课程计算机前言,《创意手工》三河小学校本课程——序言
  19. 最新的AOC有源光缆介绍,看这一篇就够了
  20. git 中 A C D M R T U X 分别解释

热门文章

  1. Qt Designer的小部件编辑模式
  2. MyCat安装,数据导入,以及安装过程中的各种参数配置
  3. HDFS的API调用,创建Maven工程,创建一个非Maven工程,HDFS客户端操作数据代码示例,文件方式操作和流式操作
  4. Linux redhat下安装swftools(转载后修改)
  5. Linux sed 删除行命令常见使用详解
  6. Kettle使用_10 存储过程与命名参数
  7. 决策树结合网格搜索交叉验证的例子
  8. CNN+LSTM+CTC
  9. python3源代码_Python3源代码编译安装
  10. 4代hiv检测50元_闲置甩干机卖了50元!大爷突然想起:里面还有4根金条