在使用MyBatis做持久层时,insert语句默认是不返回记录的主键值,而是返回插入的记录条数;显然,假如主键是你生成后插入的,自然你已经有主键了,显然不需要我们再去获得,所以我们这里处理的是当主键是数据库中主动生成的,例如主键是自增长的。如果业务层需要得到记录的主键(自增长)时,可以通过配置的方式来完成这个功能。

oracle插入数据后获得主键

  针对Sequence主键而言(oracle数据库像mysql或者sql server那样子有帮其实现自增长的声明,想要自增长需要使用sequence,并且使用触发器,当插入一行数据是,使用触发器将sequence的下一个值插入),在执行insert sql前必须指定一个主键值给要插入的记录,如Oracle、DB2,可以采用如下配置方式:

<insert id="add" parameterType="vo.Category">
<selectKey resultType="java.lang.Short" order="BEFORE" keyProperty="id">
SELECT SEQ_TEST.NEXTVAL FROM DUAL
</selectKey>
insert into category (name_zh, parent_id,
show_order, delete_status, description
)
values (#{nameZh,jdbcType=VARCHAR},
#{parentId,jdbcType=SMALLINT},
#{showOrder,jdbcType=SMALLINT},
#{deleteStatus,jdbcType=BIT},
#{description,jdbcType=VARCHAR}
)
</insert>

  分析,其实就是在原先mybatis的使用情况下。添加了

order="BEFORE" keyProperty="id"

  keyColumn的值(id)就是数据库中相应的字段

  keyProperty是Java对象的属性名。

mysql插入数据后获得主键

  针对自增主键的表,在插入时不需要主键,而是在插入过程自动获取一个自增的主键,比如MySQL,可以采用如下两种配置方式:

<insert id="add" parameterType="vo.Category" useGeneratedKeys="true" keyProperty="id">insert into category (name_zh, parent_id,show_order, delete_status, description)values (#{nameZh,jdbcType=VARCHAR},#{parentId,jdbcType=SMALLINT},#{showOrder,jdbcType=SMALLINT},#{deleteStatus,jdbcType=BIT},#{description,jdbcType=VARCHAR})</insert>

或者

<insert id="add" parameterType="vo.Category">
<selectKey resultType="java.lang.Short" order="AFTER" keyProperty="id">
SELECT LAST_INSERT_ID() AS id
</selectKey>
insert into category (name_zh, parent_id,
show_order, delete_status, description
)
values (#{nameZh,jdbcType=VARCHAR},
#{parentId,jdbcType=SMALLINT},
#{showOrder,jdbcType=SMALLINT},
#{deleteStatus,jdbcType=BIT},
#{description,jdbcType=VARCHAR}
)
</insert>

  致谢:感谢您的阅读!

mybatis 插入数据时返回主键相关推荐

  1. mysql插入时间区间_mybatis插入数据时返回主键以及MySQL根据时间区间查询问题总结...

    最近做项目的过程中,在数据库方面遇到了两个问题,一是在插入一条数据的时候需要将该条数据的主键返回.二是根据时间区间进行查询时某一天的数据查询不到,在此总结记录一下. 1.如何在插入一条数据的同时将主键 ...

  2. Mybatis insert数据时返回主键

    Mybatis insert 时候默认返回行数,想要获取主键,可以在写xml时候添加属性配置,以MySQL为例 keyProperty="id" useGeneratedKeys= ...

  3. mybatis添加记录时返回主键id

    参考:mybatis添加记录时返回主键id 场景 有些时候我们在添加记录成功后希望能直接获取到该记录的主键id值,而不需要再执行一次查询操作. 在使用mybatis作为ORM组件时,可以很方便地达到这 ...

  4. Mybatis插入数据后获取主键的值

    Mybatis插入数据后获取主键的值 1. 所使用的数据库是支持自增的,且主键是自增的 <!-- 支持自增的数据库且主键是自增的:自动将插入后自增id的值赋值给传入的Employee的id--& ...

  5. oracle批量插入并且返回自增主键_mybatis + (oracle)实现主键自增 + 插入数据并返回主键...

    一.实现主键自增 在oracle数据库中,主键并没有办法自动增长,无法使用insert对应的useGeneratedKeys和keyProperty属性自动返回增加的主键. 要实现自增需要修改 ID列 ...

  6. MyBatis在Oracle中插入数据并返回主键的问题解决

    前些天发现了一个巨牛的人工智能学习网站,通俗易懂,风趣幽默,忍不住分享一下给大家.点击跳转到教程. 前言:我早期用过这个方法,但是返回的依旧是影响行数,不是主键. 只是这种写法可以达到我要的效果: 用 ...

  7. MYSQL插入数据后返回主键

    最近做项目,要求不能使用mybatis等框架,所以一切数据库访问操作都是用原生的JDBC. 用过mybatis的都知道,插入新数据后可以直接返回主键的值,但是使用JDBC不行,于是上网搜了一下,找到一 ...

  8. MyBatis在insert插入操作时返回主键ID的配置

    在使用MyBatis做持久层时,insert语句默认是不返回记录的主键值,而是返回插入的记录条数:如果业务层需要得到记录的主键时,可以通过Mapper.XML配置的方式来完成这个功能. 在 INSER ...

  9. MyBatis在insert插入操作时返回主键ID

    数据库为MySql时:  <insert id="insert" parameterType="com.test.User" keyProperty=&q ...

最新文章

  1. Linux压缩与解压缩文件
  2. python自学第12天 模块
  3. VTK:简单操作之FloatingPointExceptions
  4. php 经纬度 距离排序,php mysql 根据经纬度计算距离和排序
  5. 关于string,我今天科普的
  6. [AHOI2009]飞行棋 BZOJ1800
  7. c语言错误重定义,C语言的重定义错误求解
  8. 图片延迟加载和滑动翻页
  9. 惠普电脑如何下载c语言软件,惠普笔记本电脑上的语言栏怎么弄
  10. 微信搜一搜品牌官方区新增视频号触点
  11. parallel(parallelStream)并发问题
  12. Greenrobot-EventBus源码学习(四)
  13. 2020低压电工作业考试题库及低压电工模拟考试系统
  14. 2012服务器清理系统盘,windows2012磁盘清理
  15. 变上限积分求导的原理
  16. Spark API 之subtract(差集)
  17. vite:vue中引入图片报错require is not defined
  18. 微信多开_电脑PC端微信双开多开
  19. Java项目:SpringBoot图书管理系统
  20. 数字电路硬件设计系列(十三)之HDMI电路设计

热门文章

  1. Debian 7.8 通过 apt-get 安装 nodejs
  2. sun.misc.Unsafe的理解
  3. F#学习:类型的定义和使用语法
  4. Idea Marketplace 加载很慢 加载不出来
  5. 解决Redis缓存雪崩、穿透、并发、预热、击穿、热点Key等问题
  6. 什么是OAuth 2.0
  7. 1、配置PHP构建环境
  8. ShardingSphere(八) 分库分表的多种分片策略
  9. golang flag.Parse包
  10. iisS7 配置SSL 绑定主机头实现多站点访问