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。选择最适合你场景的方法即可。

相关推荐
ghie90901 小时前
差速转向移动机器人基于速度的动力学模型与自适应控制器 MATLAB实现
开发语言·matlab
Coder_Boy_1 小时前
从单体并发工具类到分布式并发:思想演进与最佳实践
java·spring boot·分布式·微服务
❀͜͡傀儡师2 小时前
SpringBoot渗透扫描Scan工具
java·spring boot·后端
寻寻觅觅☆2 小时前
东华OJ-基础题-124-分数化小数(C++)-难度中
开发语言·c++·算法
hanbr10 小时前
C++ 初涉
开发语言·c++
Дерек的学习记录10 小时前
C++:入门基础(下)
开发语言·数据结构·c++·学习·算法·visualstudio
hzc098765432110 小时前
Spring Integration + MQTT
java·后端·spring
云小逸10 小时前
【nmap源码解析】Nmap 核心技术深度解析:从源码到实战
开发语言·网络·windows·nmap
前路不黑暗@10 小时前
Java项目:Java脚手架项目的公共模块的实现(二)
java·开发语言·spring boot·学习·spring cloud·maven·idea