我的类结构看起来像这样......我在这里实现了两个单独的策略,但是根类的继承策略,即 InheritanceType.JOINED 正在整个层次结构中使用......
@Entity
@Inheritance(strategy = InheritanceType.JOINED)
@DiscriminatorColumn(name = "typeName", discriminatorType = DiscriminatorType.STRING, length = 100)
@Table(name="table_A")
public abstract class A{
...
}
@Entity
@Table(name = "table_B")
@PrimaryKeyJoinColumn(name = "ID_B")
@Inheritance(strategy = InheritanceType.SINGLE_TABLE)
@DiscriminatorValue("SVC")
public abstract class B extends A {
...
}
@Entity
@DiscriminatorValue("C")
public class C extends B {
...
}
@Entity
@DiscriminatorValue("D")
public class D extends B {
...
}
当我创建一个'D'的实例并尝试持久化它时,hibernate正在寻找一个名为'D'的表......
我发现有几个人问同样的问题......但答案对我没有帮助...
混合连接和单表继承以及查询所有对象- 相同的问题..
如何将继承策略与 JPA 注释和 Hibernate 混合?- 将 single_table 与加入的混合......这对我来说没有帮助..