mybatisplus 获得新增id

在使用 MyBatis-Plus 进行数据库操作时,如果你在插入记录后需要获取新插入记录的ID,可以通过几种方式实现。MyBatis-Plus 提供了一些内置的方法来帮助你获取插入记录的ID。以下是一些常见的方法:

  1. 使用 `insert` 方法并返回自增主键

如果你的表设计中有自增主键,你可以直接插入记录,然后使用 `insert` 方法,它会返回自增的主键ID。

```java

// 假设有一个实体类 User,其中有一个自增的主键 id

User user = new User();

user.setName("张三");

user.setAge(30);

// 使用 insert 方法插入数据,并获取自增主键

int insertResult = userMapper.insert(user);

if (insertResult > 0) {

// 获取自增主键

Integer id = user.getId(); // 这里可以直接获取到插入后的ID

System.out.println("插入成功,ID: " + id);

}

```

  1. 使用 `save` 方法并返回自增主键

MyBatis-Plus 的 `save` 方法也可以用来插入数据,并返回自增的主键ID。

```java

User user = new User();

user.setName("李四");

user.setAge(25);

boolean result = userMapper.save(user);

if (result) {

Integer id = user.getId(); // 直接从实体中获取自增主键ID

System.out.println("插入成功,ID: " + id);

}

```

  1. 使用 `insert` 方法并指定返回字段

如果你不想通过实体类自动填充自增ID,或者你的表没有自增主键,你可以在插入时指定返回字段。例如:

```java

Map<String, Object> param = new HashMap<>();

param.put("name", "王五");

param.put("age", 28);

// 使用 XML Mapper 或 @Select 注解的 SQL 语句插入数据,并返回特定的字段(例如自定义的ID)

Integer id = userMapper.insertReturnId(param); // 这里的 insertReturnId 是自定义的方法名,需要在 Mapper XML 中定义或使用 @Select 注解定义 SQL 语句。

System.out.println("插入成功,ID: " + id);

```

在 Mapper XML 中定义的方法示例:

```xml

<insert id="insertReturnId" parameterType="map" useGeneratedKeys="true" keyProperty="id">

INSERT INTO user (name, age) VALUES ({name}, {age})

</insert>

```

  1. 使用 `useGeneratedKeys` 和 `keyProperty` 属性

当你使用 MyBatis 的 XML Mapper 文件时,可以在 `<insert>` 标签中添加 `useGeneratedKeys="true"` 和 `keyProperty="id"` 属性来指定返回的字段。这同样适用于 MyBatis-Plus。例如:

```xml

<insert id="insertUser" parameterType="com.example.User" useGeneratedKeys="true" keyProperty="id">

INSERT INTO user (name, age) VALUES ({name}, {age})

</insert>

```

然后在你的服务层调用这个方法:

```java

User user = new User();

user.setName("赵六");

user.setAge(32);

userMapper.insertUser(user); // 插入后,user 对象的 id 将被自动填充。

System.out.println("插入成功,ID: " + user.getId());

```

以上方法可以帮助你在使用 MyBatis-Plus 时获取插入记录的自增ID。选择最适合你场景的方法即可。

相关推荐
juniperhan3 分钟前
Flink 系列第13篇:Flink 生产环境中的并行度与资源配置
java·大数据·数据仓库·分布式·flink
咸鱼翻身小阿橙4 分钟前
Qt P5
开发语言·数据库·qt
Foreer黑爷6 分钟前
Spring MVC原理与源码:从请求到响应的全流程解析
java·spring·mvc
xxjj998a7 分钟前
Spring Boot 实战:轻松实现文件上传与下载功能
java·数据库·spring boot
Full Stack Developme8 分钟前
Hutool NumUtil 教程
开发语言·python
AI人工智能+电脑小能手8 分钟前
【大白话说Java面试题】【Java基础篇】第3题:ArrayList和LinkedList有什么区别
java·开发语言·后端·面试·list
AI人工智能+电脑小能手10 分钟前
【大白话说Java面试题】【Java基础篇】第4题:LinkedList是单向链表还是双向链表
java·开发语言·数据结构·后端·链表·面试·list
fish_xk13 分钟前
c++的list
开发语言·c++·list
Lyyaoo.2 小时前
【JAVA基础面经】JVM的内存模型
java·开发语言·jvm
杨凯凡2 小时前
【017】泛型与通配符:API 设计里怎么用省心
java·开发语言