在spring jpa中加入非唯一列

问题描述

我想在这个论坛上找到我的问题的答案。我的问题如下,我有两个类:

@Entity
@Table(name = "a")
public class A implements Serializable{

  @Id
  private String id = UUID.randomUUID().toString();

  @Column(name = "REFERENCE_ID")
  private String referenceId;

  @Column(name = "VERSION")
  private String version;
}

@Entity
@Table(name = "b")
public class B{

  @Id
  private String id = UUID.randomUUID().toString();

  @Column(name = "REFERENCE")
  private String reference;

  @ManyToMany(fetch = FetchType.LAZY)
  @NotFound(action = NotFoundAction.IGNORE)
  @JoinColumnsOrFormulas({
        @JoinColumnOrFormula(formula = @JoinFormula(value = 
                "(select r from A r where r.reference_id = reference_id order by r.version desc limit 1)",referencedColumnName = "reference_id")),@JoinColumnOrFormula(column = @JoinColumn(name = "reference_id",referencedColumnName = "reference_id",insertable = false))
        })
  private A referenceId;
}

问题是 reference_id 不是 b 表中的唯一键,而只是表 A 中的指示值,因此为了获取整个对应行,我必须对连接中的公式进行一些过滤注解。 当我尝试获取我的数据时,出现以下错误

【请求处理失败;嵌套异常是 org.springframework.dao.InvalidDataAccessResourceUsageException: 无法提取结果集; SQL [不适用];嵌套异常是 org.hibernate.exception.SQLGrammarException: 无法提取 ResultSet] 的根本原因是 org.postgresql.util.PSQLException: 错误:关系“a”不存在位置:309

编辑

实际上 t 将我的连接公式更改为按预期工作

 @JoinFormula(value = 
            "(select r from schema_A r where r.reference_id = reference_id order by r.version desc limit 1)",referencedColumnName = "reference_id"))

现在的问题是代码打算在多个环境中工作 至于我的 application.yml 看起来有点像这样;

jpa:
database: POSTGRESQL
show-sql: true
hibernate:
  ddl-auto: update
properties:
  hibernate:
    format_sql: true
    default_schema: schema
    jdbc:
      lob:
        non_contextual_creation: true
      time_zone: UTC

感谢您的回复:)

解决方法

我同意西蒙的评论。对于 Postgres(以及一般的关系数据库),“表”和“关系”这个词是相同的,“关系”这个词是从哪里来的。因此,当它说“找不到关系 B”时,它的字面意思是“找不到名为 B 的表”。

您应该检查架构的连接设置,以查看这些表是否已/尚未定义。如果不明显,可以根据您的连接设置和适当的调试相应地添加/编辑问题,显示您DO看到那里的关系(表格)。

相关问答

错误1:Request method ‘DELETE‘ not supported 错误还原:...
错误1:启动docker镜像时报错:Error response from daemon:...
错误1:private field ‘xxx‘ is never assigned 按Alt...
报错如下,通过源不能下载,最后警告pip需升级版本 Requirem...