返回顶部
首页 > 资讯 > 后端开发 > Python >mybatis中返回主键一直为1的问题
  • 706
分享到

mybatis中返回主键一直为1的问题

mybatis返回主键mybatis主键mybatis返回主键为1 2023-03-06 08:03:16 706人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录mybatis 返回主键一直为1mybatis 自增主键 主键回传,返回id为null 踩坑 Mybatis主键回传流程踩坑总结mybatis 返回主键一直为1 1是返

mybatis 返回主键一直为1

1是返回的插入成功的行数,这没有错

而自增id则是直接映射到对象里,直接输出 xxx.getId()即可

举例:

在xml中:

<insert id="addUser" parameterType="blog.model.User" useGeneratedKeys="true" keyProperty="id">
......

java中代码:

int primary = userService.addUser(user);
int id = user.getId();

上面的id就是返回的主键

mybatis 自增主键 主键回传,返回id为null 踩坑

 Mybatis主键回传流程

一、插入的实体对象中包含和数据库字段唯一对应的属性

二、xml中配置(两种方式)

方式一:

这种方式比较简单,就是在插入节点上添加 useGeneratedKeys 属性,同时设置接收回传主键的属性。

6配置完成后,我们执行一个插入操作,插入时传入一个对象,插入完成后,这个对象的 id 就会被自动赋值,值就是刚刚插入成功的id。

方式二:

这种方式是在 insert 节点中添加 selecTKEy 来实现主键回填,实际上这种方式的功能更加丰富,因为 selectKey 节点中的 sql 我们既可以在插入之前执行,也可以在插入之后执行(通过设置节点的 Order 属性为 AFTER 或者 BEFORE 可以实现),具体什么时候执行,还是要看具体的需求,如果是做主键回填,我们当然需要在插入 SQL 执行之后执行 selectKey 节点中的 SQL。

踩坑

void insertBook(InsertBook insertBook);//主键可以回填
void insertBook(@Param("ib") InsertBook insertBook);//主键不会回填

千万不要使用@Param注解!!!主键不会回填!!!

总结

以上为个人经验,希望能给大家一个参考,也希望大家多多支持编程网。

--结束END--

本文标题: mybatis中返回主键一直为1的问题

本文链接: https://lsjlt.com/news/198505.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作