V2EX = way to explore
V2EX 是一个关于分享和探索的地方
现在注册
已注册用户请  登录
NiceGeekJasonChu
V2EX  ›  Java

遇到一个很神奇的 mybatis 问题,各位大佬帮忙看看

  •  
  •   NiceGeekJasonChu · 223 天前 · 2248 次点击
    这是一个创建于 223 天前的主题,其中的信息可能已经有所发展或是发生改变。
    遇到一个很神奇的 mybatis 问题,各位大佬帮忙看看
    在使用 mybatis 根据主键更新数据的时候,使用 updateByPrimaryKeySelective 方法。更新的实体上打了主键标签(@Id ),主键 id 也不是 null ,但是就更新不了数据。
    23 条回复    2024-04-16 15:29:02 +08:00
    waterlaw
        1
    waterlaw  
       223 天前 via Android
    mybatis 什么版本不说一下 😂
    NiceGeekJasonChu
        2
    NiceGeekJasonChu  
    OP
       223 天前
    @waterlaw <dependency>
    <groupId>org.mybatis.spring.boot</groupId>
    <artifactId>mybatis-spring-boot-starter</artifactId>
    <version>1.3.2</version>
    </dependency>

    <dependency>
    <groupId>mysql</groupId>
    <artifactId>mysql-connector-java</artifactId>
    <version>8.0.13</version>
    </dependency>

    <dependency>
    <groupId>tk.mybatis</groupId>
    <artifactId>mapper</artifactId>
    <version>4.1.5</version>
    </dependency>
    NiceGeekJasonChu
        3
    NiceGeekJasonChu  
    OP
       223 天前
    SQL 日志打印出来居然不是根据主键 id 更新:
    Preparing: UPDATE admin SET name = ?,password = ?,age = ?,sex = ?,phone = ? WHERE name = ? AND password = ? AND age = ? AND sex = ? AND phone = ?
    waterlaw
        4
    waterlaw  
       223 天前
    @NiceGeekJasonChu 实体类和 Mapper 看下,tkmybatis 没用过
    NiceGeekJasonChu
        5
    NiceGeekJasonChu  
    OP
       223 天前
    @waterlaw #4
    @Table(name = "admin")
    public class Admin {

    /**
    * 主键 id
    */
    @Id
    @GeneratedValue(strategy = GenerationType.IDENTITY)
    private Integer id;

    /**
    * 用户名
    */
    @Column(name = "name")
    private String name;

    /**
    * 密码
    */
    @Column(name = "password")
    private String password;
    }
    waterlaw
        6
    waterlaw  
       223 天前
    @NiceGeekJasonChu Mapper 直接使用这个实体类 Admin 吗?还需要配置 Admin 的扫描路径吗
    waterlaw
        7
    waterlaw  
       223 天前
    我这边更新成功了 ,id 列加下注解 @Column
    @Id
    @GeneratedValue(strategy=GenerationType.IDENTITY)
    @Column(name = "id")
    private Integer id;
    waterlaw
        8
    waterlaw  
       223 天前
    不加 @Column 注解也是更新成功的,mybatis-spring-boot-starter 和 mapper 的版本和你一样
    waterlaw
        9
    waterlaw  
       223 天前
    create table admin(id int(32) primary key, name varchar(20)); 必须声明主键,否则更新失败。
    waterlaw
        10
    waterlaw  
       223 天前
    不是主键也更新成功了。create table admin(id int(32), name varchar(20));
    RedBeanIce
        11
    RedBeanIce  
       223 天前 via iPhone
    你的注解不是 mybatis 的。
    RedBeanIce
        12
    RedBeanIce  
       223 天前
    @RedBeanIce 我错了,,请使用 mybatisplus 吧,tk mapper 不行了。
    NiceGeekJasonChu
        13
    NiceGeekJasonChu  
    OP
       223 天前 via iPhone
    @waterlaw 不加 @Column 注解应该也是可以的,但是我就不行,不知道哪里出了问题
    forest997
        14
    forest997  
       223 天前
    是不是 @Id 用成了别的包的,正确的是 javax.persistence 包的,mapper.xml 的 resultMap 里面有没有配<id>
    forest997
        15
    forest997  
       223 天前
    @forest997 #14 mapper.xml 的 resultMap 里面有没有配“<id>”
    forest997
        16
    forest997  
       223 天前
    @forest997 #15 是 id 标签,怎么老被吞
    pangdundun996
        17
    pangdundun996  
       223 天前
    debug 看看 sql 生成逻辑,这种估计是内部注解处理的问题
    NiceGeekJasonChu
        18
    NiceGeekJasonChu  
    OP
       223 天前 via iPhone
    @forest997 这个我检查过了,是 javax. persistence
    NiceGeekJasonChu
        19
    NiceGeekJasonChu  
    OP
       223 天前 via iPhone
    @pangdundun996 debug 过了,日志也打了,where 条件里面压根就没有 id ,打印日志我上面发过
    NiceGeekJasonChu
        20
    NiceGeekJasonChu  
    OP
       222 天前
    问题找到了,我在主键上加上 @Column(name = "id")注解,就能更新成功。但是我看有的人没有加这个注解,也能更新成功。
    xuanbg
        21
    xuanbg  
       222 天前
    你这是表没有主键吧
    pangdundun996
        22
    pangdundun996  
       222 天前
    @NiceGeekJasonChu 我意思是你看看生成 sql 的逻辑,看框架是怎么处理注解的
    NiceGeekJasonChu
        23
    NiceGeekJasonChu  
    OP
       222 天前 via iPhone
    @xuanbg 表是建了主键的,就是实体上主键 id 没有加 @Column 注解。实体上加了就正常了,但是我看有的人没加也能成功,我不加就不行
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   2820 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 20ms · UTC 09:27 · PVG 17:27 · LAX 01:27 · JFK 04:27
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.