mybatis插入数据时,自动获取主键的自增id

    自己在写博客时,遇到了一个小问题,新增博客的时候,无法得到新增博客的id
    由于设计的数据库中博客id是自增长的主键,由数据库自动生成,所以只能先插入博客后,再获取它的id。

解决方法:在mapper.xml文件里设置属性
在insert方法中添加以下两个属性即可

  1. useGeneratedKeys
  2. keyProperty
<!--useGeneratedKeys="true";使用自增主键获取主键值策略
    keyProperty;指定对应的主键属性,也就是mybatis获取到主键值以后,将这个值封装给javaBean的哪个属性
-->
<insert id="saveBlog" parameterType="Blog" useGeneratedKeys="true" keyProperty="id">

    insert into t_blog (title, content, type_id, tag_ids)
    
    values (#{title}, #{content},#{typeId}, #{tagIds});
    
</insert>

插入成功后,会直接赋值到参数bean的id中;
然后在业务层获取即可:

public int saveBlog(Blog blog) {

    //保存博客
    blogDao.saveBlog(blog);
    //保存博客后才能获取自增的id
    Long id = blog.getId();//mybatis返回的主键id
    
    //...其他操作
}
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Mitsuha三葉

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值