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函数的返回值。

相关推荐
24kHT29 分钟前
xml映射文件的方式操作mybatis
xml·mybatis
Another Iso36 分钟前
CentOs 7 MySql8.0.23之前的版本主从复制
linux·mysql·centos
张先shen2 小时前
Spring Boot集成Redis:从配置到实战的完整指南
spring boot·redis·后端
Q_Q5110082852 小时前
python的婚纱影楼管理系统
开发语言·spring boot·python·django·flask·node.js·php
周杰伦的稻香3 小时前
MySQL密码管理器“mysql_config_editor“
数据库·mysql
czhc11400756634 小时前
LINUX712 MYSQL;磁盘分区;NFS
数据库·mysql·adb
一线大码4 小时前
Gradle 高级篇之构建多模块项目的方法
spring boot·gradle·intellij idea
叁沐4 小时前
MySQL 13 为什么表数据删掉一半,表文件大小不变?
mysql
不太可爱的大白4 小时前
Mysql:分库分表
数据库·mysql
四季豆豆豆4 小时前
博客项目 laravel vue mysql 第四章 分类功能
vue.js·mysql·laravel