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

相关推荐
顺风尿一寸10 分钟前
从 Java NIO poll 到 Linux 内核 poll:一次系统调用的完整旅程
java
程途知微12 分钟前
JVM运行时数据区各区域作用与溢出原理
java
华仔啊3 小时前
为啥不用 MP 的 saveOrUpdateBatch?MySQL 一条 SQL 批量增改才是最优解
java·后端
xiaoye20185 小时前
Lettuce连接模型、命令执行、Pipeline 浅析
java
beata8 小时前
Java基础-18:Java开发中的常用设计模式:深入解析与实战应用
java·后端
Seven978 小时前
剑指offer-81、⼆叉搜索树的最近公共祖先
java
雨中飘荡的记忆1 天前
保证金系统入门到实战
java·后端
Nyarlathotep01131 天前
Java内存模型
java
暮色妖娆丶1 天前
不过是吃了几年互联网红利罢了,我高估了自己
java·后端·面试