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中配置(两种方式)
方式一:
这种方式比较简单,就是在插入节点上添加 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注解!!!主键不会回填!!!
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
相关文章
Intellij idea下使用不同tomcat编译maven项目的服务器路径方法详解
今天小编就为大家分享一篇关于Intellij idea下使用不同tomcat编译maven项目的服务器路径方法详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧2019-02-02SpringBoot3整合MyBatis出现异常:Property 'sqlSessionFactory&a
这篇文章主要介绍了SpringBoot3整合MyBatis报错:Property ‘sqlSessionFactory‘ or ‘sqlSessionTemplate‘ are required,其实不是个大问题,只是自己编码时遇到了,然后总结总结分享一下,如果有遇到类似问题的,可以参考一下2022-11-11
最新评论