springboot mybatis mysql新增后返回id(ai生成)

在Spring Boot项目中使用MyBatis和MySQL时,若想在插入数据后返回生成的ID,可以在Mapper接口的插入方法上使用@Options注解,并设置useGeneratedKeys属性为true,同时指定keyProperty为实体类中对应ID的属性名。

以下是一个简单的示例:

1、实体类(假设为User):

java 复制代码
public class User {
    private Long id; // 假设ID是自增长的Long类型
    private String name;
    // 省略其他属性、构造函数、getter和setter方法
}

2、Mapper接口:

java 复制代码
@Mapper
public interface UserMapper {
    @Insert("INSERT INTO users (name) VALUES (#{name})")
    @Options(useGeneratedKeys = true, keyProperty = "id")
    void insertUser(User user);
}

在上述代码中,当insertUser方法被调用时,插入操作执行后,MyBatis会自动将生成的ID回填到传入对象的id属性中。

确保MySQL表的ID列设置了自增属性,例如:

sql 复制代码
CREATE TABLE users (
  id INT NOT NULL AUTO_INCREMENT,
  name VARCHAR(50),
  PRIMARY KEY (id)
);

这样,在插入记录后,MyBatis就会把生成的ID设置到User对象的id属性上。

注意

返回id赋值了user对象的id,不是insertUser函数的返回值。

相关推荐
i***586717 小时前
springcloud springboot nacos版本对应
spring boot·spring·spring cloud
s***385617 小时前
SpringBoot中如何手动开启事务
java·spring boot·spring
i***220717 小时前
springboot整合libreoffice(两种方式,使用本地和远程的libreoffice);docker中同时部署应用和libreoffice
spring boot·后端·docker
代码or搬砖18 小时前
SpringMVC的执行流程
java·spring boot·后端
菜鸟小九18 小时前
mysql(锁)
数据库·mysql·oracle
q***160818 小时前
SpringCloud 系列教程:微服务的未来(二)Mybatis-Plus的条件构造器、自定义SQL、Service接口基本用法
spring cloud·微服务·mybatis
极光代码工作室18 小时前
基于SpringBoot的流浪狗管理系统的设计与实现
java·spring boot·后端
思密吗喽18 小时前
景区行李寄存管理系统
java·开发语言·spring boot·毕业设计·课程设计
star_111219 小时前
Jenkins部署后端springboot微服务项目
spring boot·微服务·jenkins
云和数据.ChenGuang19 小时前
运维面试题之oracle和mysql单表最大容量
运维·mysql·oracle