java – 使用“mappedBy”与Super类成员的多个ManyToMany关系

我正在使用Hibernate开发一个应用程序,并试图模拟以下场景:

我有一个Activity Abstract类,定义如下:

@Entity
@Inheritance(strategy=InheritanceType.SINGLE_TABLE)
@DiscriminatorColumn(name="activityType")
@Table(name = "BF_ACTIVITY")
public abstract class Activity extends PersistableObject {

    @ManyToOne
    @JoinColumn(name = "ASSIGNED_TO")
    protected  Contactable assignedTo;

    @ManyToOne
    @JoinColumn(name = "RAISED_BY")
    protected  Contactable raisedBy;

注意我正在使用单表继承(因此所有实现对象将使用相同的表)并设置了DiscriminatorColumn.

现在我有两个扩展Activity:ToDo和Status的对象:

@Entity
@Table(name = "BF_TODO")
@DiscriminatorValue("Todo")
public class ToDo extends Activity {
...


@Entity
@Table(name = "BF_STATUS")
@DiscriminatorValue("Status")
public class Status extends Activity {
...

再次注意,对于这两种实现,我都设置了DiscriminatorValue.

最后,我想要一个Person对象,这个人可以有一个Status列表和一个ToDo列表 – 我也想捕获双向关系,所以我使用mappedBy配置对它建模,但在两种情况下使用超级类“Activity”中存在的“raisedBy”字段:

public abstract class Person {

    @ManyToMany(mappedBy="raisedBy", targetEntity=Activity.class)
    private List<ToDo> todoItems = new ArrayList<ToDo>();

因为我使用来自超类的成员变量“raisedBy”的mappedBy,我还指定了targetEntity(否则它无法在ToDo对象中找到该字段).

问题是当我尝试调用getTodoItems()时 – 它实际上只是将“raiseBy”链接的所有“Activity”对象返回给当前人.例如它会抛出一个强制转换异常,因为它期望ToDos列表,但Hibernate也会返回列表中的Status对象.

我希望mappedBy配置和DiscriminatorValue足以使这项工作 – 任何人都遇到过这个或解决它?

谢谢

编辑

我刚发现这篇文章:

有人能指出我在一个好的@Where概述和例子的方向?我可以如下更新我的人,使用@Where与鉴别器列?

public abstract class Person {

    @ManyToMany(mappedBy="raisedBy", targetEntity=Activity.class)
    @Where(clause="activityType=Todo")
    private List<ToDo> todoItems = new ArrayList<ToDo>();

最佳答案 添加注释:

@Where(clause =“activityType =’Todo’”)

但这是一个hibernate注释,而不是JPA

点赞