gpt4 book ai didi

java - jpa:具有自引用和非抽象父类(super class)的继承

转载 作者:行者123 更新时间:2023-12-01 15:00:36 26 4
gpt4 key购买 nike

在我当前的项目中,我有一个如下所示的继承结构:

@Entity
@Table(name="groups")
@Inheritance(strategy=InheritanceType.JOINED)
@DiscriminatorValue("G")
@DiscriminatorColumn(name="group_type")
public class Group{ //some annotations removed
private Long id;
private String name;
private Set<Subject> subjects;
@ManyToOne(cascade=CascadeType.ALL)
@JoinColumn(name="parent_group_id")
private Group parent; ##### tree parent ####
@OneToMany(cascade=CascadeType.ALL, mappedBy="parent")
private Set<Group> subGroups; ##### tree children #####
...
}

我的Group对象可以通过包含其他 Group 的列表来具有类似树的结构。对象。由于某些组有点特殊,因此有第二个类扩展了该类:

   @Entity
@DiscriminatorValue("C")
@Table(name="fix_groups")
public class FixGroup extends Group{
private Layout lay;
private Set<Person> instr;
...
}

我尝试使用连接的多表方法(如下所述: http://en.wikibooks.org/wiki/Java_Persistence/Inheritance#Joined.2C_Multiple_Table_Inheritance ),但它似乎不适用于像 Group 这样的非抽象父类(super class)。 !我收到以下异常:

Caused by: java.lang.ClassCastException: org.hibernate.mapping.JoinedSubclass 
cannot be cast to org.hibernate.mapping.RootClass

除了声明 Group 之外还有其他解决方案吗?作为抽象并创建一个新类 Group2那只是延伸它吗?如果我这样做,这个 self 引用Set<Group> subGroups会吗?仍然会造成问题吗?

最佳答案

当子类中的 ID 已映射到父类(在本例中为 Group)中时,我可以通过在子类中设置 ID 来导致此错误。例如在父类中:

@Entity
@Table(name="groups")
@Inheritance(strategy=InheritanceType.JOINED)
public class Group {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "ID")
private Long id;
...

然后在子类中设置 id,如下所示:

@Entity
@Table(name="sub_groups")
public class SubGroup extends Group {
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "ID")
private Long id;
...

在这种情况下,Group不需要是抽象的,但是你不能在子类上定义id。

此外,作为旁注,如果您使用具有“join”类型继承的 Hibernate,则不需要鉴别器列和值。 Hibernate 仅在使用单个表时才使用这些。请引用这篇文章以获取更多信息:

Hibernate 4: persisting InheritanceType.JOINED discriminator column values

关于java - jpa:具有自引用和非抽象父类(super class)的继承,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13708417/

26 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com