Mybatis 在 insert 插入操作后返回主键 id

方法:
在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中调用的函数的返回值

  • 6
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值