当前位置: 首页 > 面试题库 >

使用JPA,Hibernate进行PostgreSQL继承

姜飞飙
2023-03-14
问题内容

我们对PostgreSQL中的继承以及在JPA中将其映射为实体存在疑问。我们的数据库和我们要映射的表是:

CREATE TABLE Answer (
    idAnswer SERIAL,
    answerContent VARCHAR,
    idQuestion INTEGER,
    version INTEGER,

    CONSTRAINT Answer_idAnswer_PK PRIMARY KEY (idAnswer),
    CONSTRAINT Answer_idQuestion_FK FOREIGN KEY (idQuestion) REFERENCES Question(idQuestion)
);


CREATE TABLE MatchAnswer (
    matchingAnswer VARCHAR NOT NULL,
    version INTEGER,

    CONSTRAINT MatchAnswer_idAnswer_PK PRIMARY KEY (idAnswer)       
) INHERITS(Answer);


CREATE TABLE TrueFalseAnswer (
    isTrue BOOLEAN NOT NULL,
    version INTEGER,

    CONSTRAINT TrueFalseAnswer_idAnswer_PK PRIMARY KEY (idAnswer)   
) INHERITS(Answer);

我们在Netbeans 7.1.2中使用自动工具将它们映射到实体。起初我认为仅添加就足够了

@Entity
@Table(name = "truefalseanswer", catalog = "jobfairdb", schema = "public")
@XmlRootElement
public class Truefalseanswer extends Answer implements Serializable {
    private static final

因此,它只是 扩大了 ,但无法正常工作。最好的方法是什么?提前致谢。


问题答案:

JPA的继承概念基于普通表。它并没有真正“理解” PostgreSQL表继承的想法。这是使用旨在暴露功能的最低公分母并且可移植的规范的成本之一。

有关JPA继承策略的详细概述,请参见本指南。请注意,在较新的Java 6 JavaDoc for
@Inheritance中,
有一条注释指出:

如果未指定Inheritance注释,或者未为实体类层次结构指定继承类型,则使用SINGLE_TABLE映射策略。

…如果您看一下如何SINGLE_TABLE运作,也就不足为奇了;期望所有子类都在一个大表中,并具有一个魔术区分值。

InheritanceType.TABLE_PER_CLASS与Pg的行为更接近,但是我怀疑当基本类型表为每个叶子类型的实体提供条目时,JPA
impl会变得有些困惑。UNION在超类上进行查询时,它会尝试在子类表之间进行查询,这可能会产生奇怪的结果-
如果UNION使用,至少会产生重复,如果使用则会产生性能问题UNION ALL。根据提供者实施该策略的方式的不同,它可能至少部分起作用。您必须进行测试,结果可能是特定于提供程序的。

对JPA的PG继承支持的一个很好的实现可能需要JPA提供者扩展才能使用新的继承策略,该策略应了解PostgreSQL扩展的继承和ONLY查询。

如果您可以说服JPA实现SELECT ... FROM ONLY subclass_tableInheritanceType.TABLE_PER_CLASS模式下使用,那么它应该可以与PostgreSQL继承互操作。它将仅看到每个表中的非继承行,并像对待普通表一样使用它们。然后,其他非JPA代码可以继续使用继承功能。我想您可能可以为Hibernate修改PostgreSQL方言代码来做到这一点,但是就我个人而言,除非我绝对
必须 让JPA支持严重依赖于继承的PostgreSQL模式,否则我不会去那里。



 类似资料:
  • 问题内容: 您将如何在以下示例代码中配置注释?我只想保留JPA注释,避免使用Hibernate特定的依赖项。 下面的代码正确吗? (这些类将具有多个版本,RefSomeOtherExample等,并且每个类一个db表。有些可能会添加其他字段(列),但大多数只会使用继承自“ RefData”基类的基本字段。) 基类: 最终,我想使用Hibernate的SchemaExport类从中生成模式创建脚本。

  • 问题内容: 有没有一种方法可以将Point列映射到Java实体字段? 我尝试了Hibernate Spatial 4.0,但似乎没有PostGIS的纯PostgreSQL就无法使用。这是点字段定义: persistence.xml中的方言: 当我尝试保留该实体时,会引发异常: 似乎它试图将值保留为PostGIS的Geometry类型。但是我只想使用简单的Point。 问题答案: 您应该尝试在数据库

  • 问题内容: 我正在使用JPA和Hibernate和Postgresql开发应用程序。使用Netbeans向导,我从现有数据库中创建了实体类。这些类之一的摘录如下: 在EJB中,我有: 当我尝试执行时,会产生以下错误: 我知道Postgres对于大写的表名有点烦人,但是如何更改查询以指向“ ADM_TYPES”而不是AdmTypes?这不是应该自动完成吗(毕竟我是从现有数据库中创建实体类的)?代码有

  • 有没有办法将点列映射到Java实体字段? 我尝试了Hibernate空间4.0,但似乎它不适用于没有PostGIS的纯PostgreSQL。这里是点字段定义: persistence.xml方言: 当我尝试持久化这个实体时,会引发异常: 因此,它似乎试图将价值作为PostGIS的几何类型。但是我想用简单的Point。

  • 我有一个带有spring Boot(v2.3.3)和spring数据的spring web应用程序。我的评估表包含以下列: Id 我的用例是表中名称和地址的任何更改评估应该创建一个新行,版本以相同的id递增。 因此,基本上只有当地址或姓名更新时,才能在评估表中插入新记录。下面是一个示例: 现有记录: 例如,名称已更新为Ryan,应该有两行,如下所示: 因此,基本上,任何名称和地址的变化都应在评估表

  • 我有一个项目,其中一部分数据结构是用@ Inheritance(strategy = Inheritance type)制作的。已加入)。数据结构的这一部分看起来像这样: 该设计基于本文的思想。我使用Hibernate和JPA2接口作为我的数据层。上面的结构产生了下面的pojo/dao类(省略了getter和setter): 基本项: 物理项目: 一些硬件: 其他硬件: 这是我的问题: 我的另一个