这是我的 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 驱动那边的异常,但没具体告诉我该怎么去排查解决,网上也没搜到这种类似的问题。
1
Oktfolio 2022-06-01 11:13:25 +08:00
如果 driver 是最新版尝试降 org.postgresql:postgresql 版本,如果不是,尝试升级最新版
|
2
Oktfolio 2022-06-01 11:17:40 +08:00
更换版本不能解决的话,不是 sqlparser 的问题,就是 mybatis-plus 的问题
|
3
y830CAa5nink4rUQ 2022-06-01 11:33:44 +08:00
你的表确认存在这个字段吗?
|
4
micean 2022-06-01 12:35:06 +08:00
是不是大小写的问题?
|
5
TuringHero 2022-06-01 12:37:48 +08:00
这代码看着真难受,类名属性名一样或者驼峰能对应的话注解可以省略的
|
6
aircjm 2022-06-01 14:46:49 +08:00
xml 写法救命啊
|
7
ccccccccw 2022-06-01 16:22:51 +08:00
createdby 还是 createdbBy ,postgresql 貌似默认忽略大小写,如果强制要 createdBy 的话,要加上'createdBy'
|
9
esbug OP 问题是解决了。方法就是在 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> |
10
OldCarMan 2022-06-02 11:18:21 +08:00
话说你们表和字段命名也是驼峰式的吗?还是迫于历史遗留必须统一风格的无奈?或是我孤陋寡闻,见识太少了。生产环境中我还没见过有人这么命名的,基本都是小写字母构成的单词、“_”和数字这三种组合而成的命名风格。
|
11
xinJang 2022-06-02 14:12:50 +08:00
|
12
xinJang 2022-06-02 14:13:28 +08:00
印象中是反序列化报错,是不是要替换 json 包才可以
|