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

Java +postgresql 无法映射父类实体

  •  
  •   esbug · 2022-06-01 11:08:52 +08:00 · 2152 次点击
    这是一个创建于 910 天前的主题,其中的信息可能已经有所发展或是发生改变。

    这是我的 BaseEntity

    package com.txys.system.entity;
    
    import com.baomidou.mybatisplus.annotation.TableField;
    import com.baomidou.mybatisplus.extension.activerecord.Model;
    import lombok.Data;
    
    @Data
    public abstract class BaseEntity<T> extends Model<BaseEntity<T>> {
    
        @TableField(value = "createdBy")
        private String createdBy;
    
        @TableField(value = "createdAt")
        private String createdAt;
    
        @TableField(value = "updatedAt")
        private String updatedAt;
    
        @TableField(value = "updatedBy")
        private String updatedBy;
    
        @TableField(value = "deletedAt")
        private String deletedAt;
    }
    
    

    这是我的 SystemUser 表

    package com.txys.system.entity;
    
    import com.baomidou.mybatisplus.annotation.IdType;
    import com.baomidou.mybatisplus.annotation.TableField;
    import com.baomidou.mybatisplus.annotation.TableId;
    import com.baomidou.mybatisplus.annotation.TableName;
    import lombok.Data;
    
    import java.io.Serializable;
    
    @TableName("\"SystemUser\"")
    @Data
    public class SystemUser extends BaseEntity<SystemUser> implements Serializable {
    
        @TableId(value = "id", type = IdType.AUTO)
        private Integer id;
    
        @TableField(value = "username")
        private String username;
    
        @TableField(value = "password")
        private String password;
    }
    

    ###1 、我现在的问题是:继承了 BaseEntity 父类,调用 selectById ,

    SELECT id,username,password,createdBy,createdAt,updatedAt,updatedBy,deletedAt FROM "SystemUser" WHERE id=?
    

    查询时会自动加上父类继承的字段,如果父类字段加上 exsit=false ,那么查询就也不会带上父类字段,但以前使用 MySQL 的时候是可以被识别的。

    查询结果映射的时候,会报错:

    Error querying database. Cause: org.postgresql.util.PSQLException: 错误: 字段 "createdby" 不存在

    也就是说:映射找不到继承的父类公共字段

    问过 mybatis-plus 官方,他们说是 postgresql 驱动那边的异常,但没具体告诉我该怎么去排查解决,网上也没搜到这种类似的问题。

    12 条回复    2022-06-02 14:13:28 +08:00
    Oktfolio
        1
    Oktfolio  
       2022-06-01 11:13:25 +08:00
    如果 driver 是最新版尝试降 org.postgresql:postgresql 版本,如果不是,尝试升级最新版
    Oktfolio
        2
    Oktfolio  
       2022-06-01 11:17:40 +08:00
    更换版本不能解决的话,不是 sqlparser 的问题,就是 mybatis-plus 的问题
    y830CAa5nink4rUQ
        3
    y830CAa5nink4rUQ  
       2022-06-01 11:33:44 +08:00
    你的表确认存在这个字段吗?
    micean
        4
    micean  
       2022-06-01 12:35:06 +08:00
    是不是大小写的问题?
    TuringHero
        5
    TuringHero  
       2022-06-01 12:37:48 +08:00
    这代码看着真难受,类名属性名一样或者驼峰能对应的话注解可以省略的
    aircjm
        6
    aircjm  
       2022-06-01 14:46:49 +08:00
    xml 写法救命啊
    ccccccccw
        7
    ccccccccw  
       2022-06-01 16:22:51 +08:00
    createdby 还是 createdbBy ,postgresql 貌似默认忽略大小写,如果强制要 createdBy 的话,要加上'createdBy'
    ccccccccw
        8
    ccccccccw  
       2022-06-01 16:24:49 +08:00
    @ccccccccw 记错了,好想是"createdBy"
    esbug
        9
    esbug  
    OP
       2022-06-01 18:52:05 +08:00
    问题是解决了。方法就是在 BaseEntity ,对字符串转义。
    ```java
    @Data
    public abstract class BaseEntity<T> extends Model<BaseEntity<T>> {

    @TableField(value = "\"createdBy\"")
    private String createdBy;

    @TableField(value = "\"createdAt\"")
    private String createdAt;

    @TableField(value = "\"updatedAt\"")
    private String updatedAt;

    @TableField(value = "\"updatedBy\"")
    private String updatedBy;

    @TableField(value = "\"deletedAt\"")
    private String deletedAt;
    }

    ```
    <a href="https://imgtu.com/i/XJq6Z4"><img src="https://s1.ax1x.com/2022/06/01/XJq6Z4.png" alt="XJq6Z4.png" border="0" /></a>
    OldCarMan
        10
    OldCarMan  
       2022-06-02 11:18:21 +08:00
    话说你们表和字段命名也是驼峰式的吗?还是迫于历史遗留必须统一风格的无奈?或是我孤陋寡闻,见识太少了。生产环境中我还没见过有人这么命名的,基本都是小写字母构成的单词、“_”和数字这三种组合而成的命名风格。
    xinJang
        11
    xinJang  
       2022-06-02 14:12:50 +08:00
    插个楼。怎么直接映射 pg 数据库里的 json 格式。
    pom 里面引入了 hibernate-types-52
    entity 里面也配置了
    类注解 @TypeDef(name = "json", typeClass = JsonBinaryType.class)
    属性注解 @Type(type = "json")
    @Column(columnDefinition = "jsonb")
    xinJang
        12
    xinJang  
       2022-06-02 14:13:28 +08:00
    印象中是反序列化报错,是不是要替换 json 包才可以
    关于   ·   帮助文档   ·   博客   ·   API   ·   FAQ   ·   实用小工具   ·   5483 人在线   最高记录 6679   ·     Select Language
    创意工作者们的社区
    World is powered by solitude
    VERSION: 3.9.8.5 · 24ms · UTC 08:35 · PVG 16:35 · LAX 00:35 · JFK 03:35
    Developed with CodeLauncher
    ♥ Do have faith in what you're doing.