Mybatis插入操作后如何正确获取返回的主键值?

2026-05-16 01:240阅读0评论SEO资源
  • 内容介绍
  • 文章标签
  • 相关推荐

本文共计590个文字,预计阅读时间需要3分钟。

Mybatis插入操作后如何正确获取返回的主键值?

MyBatis添加记录后获取主键ID,这是一个常见的需求。该需求分为两种情况:(1)添加单条记录时获取主键值;(2)批量添加记录时获取每条记录的主键值。注意:从3.3.1版本开始,MyBatis提供了更好的支持。

MyBatis添加记录后获取主键ID,这是一个很常见的需求。这个需求有分为两种情况:(1)添加单条记录时获取主键值;(2)获取批量添加记录时各记录的主键值。

备注:MyBatis从3.3.1版本开始支持批量添加记录并返回各记录主键字段值。

1、添加单一记录时返回主键ID(方法一)

此种方法主要思路是:使用<insert>标签或者@Insert注解的属性:useGeneratedKeys、keyProperty、keyColumn。下面分别以xml映射器和注解映射器分别详细阐述一下。

2、添加单一记录时返回主键ID(方法二)

在上面方法一中,如何获取自增的id呢,估计很多人还有点疑惑,其实原理很简单:当插入数据之后,mybatis再次查询mysql数据库,获得了注解id,然后填充到person对象的id属性的。

业务中,会遇到这样的问题,就是感觉返回的主键,插入作为其他表的外键。

那么问题来了,如何去实现,其实方法比较简单,这里就是重点记录下,会出现的误区。

阅读全文

本文共计590个文字,预计阅读时间需要3分钟。

Mybatis插入操作后如何正确获取返回的主键值?

MyBatis添加记录后获取主键ID,这是一个常见的需求。该需求分为两种情况:(1)添加单条记录时获取主键值;(2)批量添加记录时获取每条记录的主键值。注意:从3.3.1版本开始,MyBatis提供了更好的支持。

MyBatis添加记录后获取主键ID,这是一个很常见的需求。这个需求有分为两种情况:(1)添加单条记录时获取主键值;(2)获取批量添加记录时各记录的主键值。

备注:MyBatis从3.3.1版本开始支持批量添加记录并返回各记录主键字段值。

1、添加单一记录时返回主键ID(方法一)

此种方法主要思路是:使用<insert>标签或者@Insert注解的属性:useGeneratedKeys、keyProperty、keyColumn。下面分别以xml映射器和注解映射器分别详细阐述一下。

2、添加单一记录时返回主键ID(方法二)

在上面方法一中,如何获取自增的id呢,估计很多人还有点疑惑,其实原理很简单:当插入数据之后,mybatis再次查询mysql数据库,获得了注解id,然后填充到person对象的id属性的。

业务中,会遇到这样的问题,就是感觉返回的主键,插入作为其他表的外键。

那么问题来了,如何去实现,其实方法比较简单,这里就是重点记录下,会出现的误区。

阅读全文