关于mybatis中添加数据时,返回主键id的方法

本文介绍了在使用Mybatis进行数据库插入时,如何配置返回自增主键ID的技巧,包括设置`useGeneratedKeys`和`keyProperty`,并通过示例展示了完整的流程,包括获取openid、判断新用户以及生成JWT令牌。
摘要由CSDN通过智能技术生成

关于mybatis中添加数据时,返回主键id的方法

1.场景

在添加到数据库中需要返回主键id时遇到该问题

2.如何解决

首先我们需要知道两个关键字

//是否返回自增主键值

useGeneratedKeys = true

//将值附给哪个属性 这个属性必须是实体类中包含的

keyProperty = “id”

<insert id="insert" useGeneratedKeys="true" keyProperty="id">
        insert into user ( openid, name, phone, sex, id_number, avatar, create_time)
            values ( #{openid}, #{name}, #{phone}, #{sex}, #{idNumber}, #{avatar}, #{createTime})
</insert>

这样就可以在我们调用insert方法时 给原来的实体类中含有的属性赋值

  //调用微信接口服务来获得当前用户的openid
       String openid = this.getOpenid(dto);

        //判断是否为空 如果为空登录失败 抛出业务异

        if (openid == null){
            throw new LoginFailedException(MessageConstant.LOGIN_FAILED);
        }

        //当前微信用户是不是新用户
        User user = userMapper.getByOpenid(openid);
        if (user == null){
            //判断当前用户,自动完成注册
            user= User.builder().openid(openid).createTime(LocalDateTime.now()).build();
            userMapper.insert(user);
        }


        //返回这个用户对象
        HashMap<String, Object> claims = new HashMap<>();
        claims.put(JwtClaimsConstant.USER_ID,user.getId());
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值