开发者

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

开发者 https://www.devze.com 2023-03-05 10:25 出处:网络 作者: mikaelzero
目录myBATis 返回主键一直为1mybatis 自增主键 主键回传,返回id为null 踩坑 Mybatis主键回传流程踩坑总结mybatis 返回主键一直为1
目录
  • myBATis 返回主键一直为1
  • mybatis 自增主键 主键回传,返回id为null 踩坑
    •  Mybatis主键回传流程
    • 踩坑
  • 总结

    mybatis 返回主键一直为1

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

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

    举例javascript

    在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的问题

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

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

    方式二:

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

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

    踩坑

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

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

    总结

    以上为个人经验,希望能给大家一个参考,也希望大家多多支javascript持我们。

    0

    精彩评论

    暂无评论...
    验证码 换一张
    取 消

    关注公众号