mybatis中返回主键一直为1的问题怎么解决

发布时间:2023-03-07 15:46:39 作者:iii
来源:亿速云 阅读:138

今天小编给大家分享一下mybatis中返回主键一直为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中配置(两种方式)

方式一:

mybatis中返回主键一直为1的问题怎么解决

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

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

方式二:

mybatis中返回主键一直为1的问题怎么解决

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

踩坑

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

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

以上就是“mybatis中返回主键一直为1的问题怎么解决”这篇文章的所有内容,感谢各位的阅读!相信大家阅读完这篇文章都有很大的收获,小编每天都会为大家更新不同的知识,如果还想学习更多的知识,请关注亿速云行业资讯频道。

推荐阅读:
  1. mybatis在oracle插入对象后返回主键值
  2. Mybatis源码[01.SqlSessionFactoryBuilder]

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

mybatis

上一篇:Angular6升级到Angular8报错如何解决

下一篇:Java怎么使用jdbc连接实现对MySQL增删改查

相关阅读

您好,登录后才能下订单哦!

密码登录
登录注册
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》