servce层获得 mybatisPlus 插入后bigint类型的自增主键
时间: 2024-01-13 15:02:24 浏览: 70
在使用 MybatisPlus 插入数据时,如果表中有自增主键(如 MySQL 中的 bigint 类型的自增主键),可以通过以下方式获取插入后的主键值:
1. 在实体类中使用 @TableId 注解标注自增主键,并设置注解的 type 属性为 IdType.AUTO,示例代码如下:
```java
@TableName("user")
public class User {
@TableId(type = IdType.AUTO)
private Long id;
private String name;
private Integer age;
// getter and setter methods
}
```
2. 在 Service 层中使用 MybatisPlus 提供的 save 方法插入数据,示例代码如下:
```java
User user = new User();
user.setName("张三");
user.setAge(20);
userService.save(user);
Long id = user.getId(); // 获取插入后的主键值
```
注意:在插入数据时,如果使用 MybatisPlus 提供的 saveOrUpdate 方法,需要先判断实体类中的自增主键是否为 null,如果不为 null,则认为该数据已存在,会执行更新操作而不是插入操作,此时无法获取插入后的主键值。
阅读全文