方法:
在xml文件里,配置 useGeneratedKeys 和 keyProperty
如图:
useGeneratedKeys=“true” 表示给主键设置自增长。
keyProperty=“id” 表示将自增长后的 Id 赋值给实体类中的 id 字段。
提醒
这里最重要的是配置 useGeneratedKeys 和 keyProperty之后,返回的主键是给了传给Mapper的实体类参数。
这是我写的示例:
Controller文件
//Controller.jave
@RestController
@RequestMapping("/user")
public class UserController {
@Autowired
private UserMapper userMapper;
@GetMapping("/temp")
public void temp(@RequestBody User user){
System.out.println("1::::::"+user);
userMapper.temp(user);
System.out.println("3::::::"+user);
}
}
Mapper文件
@Mapper
public interface UserMapper {
void temp(User user);
}
Mapper.xml文件
<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper
PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper namespace="com.example.springboot.mapper.UserMapper">
<insert id="temp" parameterType="com.example.springboot.entity.User" useGeneratedKeys="true" keyProperty="id">
insert into sys_user(username,password,nickname,email,phone,address)
values (#{username},#{password},#{nickname},#{email},#{phone},#{address})
</insert>
</mapper>
用到的实体类
@Data
public class User {
private Integer id;
private String username;
@JsonIgnore//不让该属性传给前端
private String password;
private String nickname;
private String email;
private String phone;
private String address;
}
这是运行结果:
从运行结果上可以很清晰的看出来,返回的主键的值是给了传给mapper的参数。而不是惯性思维中的mapper中调用的函数的返回值