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