4

我知道这可以通过 HQL 查询轻松解决,但是我更喜欢让 Hibernate 使用一些 OneToMany 属性来处理这个问题。

让我演示一下我希望我的域模型在伪代码中的样子:

Game
  Long GameID
  Team HomeTeam
  Team AwayTeam
  @OneToMany(mappedBy="team")
  Set<TeamPlay> HomeTeamPlays
  @OneToMany(mappedBy="team")
  Set<TeamPlay> AwayTeamPlays

表结构类似,Game 表上有两个外键都指向 Team 表。显然,如果只有一个外键,那么它将代表真正的一对多关系,但实际上我想要的是同一实体子类型的两个双向一对多属性。

我不相信使用 @Where 注释会起作用,因为它需要一个常量,并且这里不允许使用 @JoinColumn。如果不可能,那没关系,我只是想从别人那里得到它。

4

2 回答 2

8

我敢打赌,您并不真正了解 mappedBy 的用法。

您可以参考我在https://stackoverflow.com/a/13812047/395202中的其他答案

简而言之,mappedBy 是双向关系“对面”中的属性名称。

对于你的情况,它可能看起来像:

class TeamPlay {
    @ManyToOne
    Team homeTeam;

    @ManyToOne
    Team awayTeam;
}

class Team {
    @OneToMany(mappedBy="homeTeam")
    Set<TeamPlay> homeTeamPlays;

    @OneToMany(mappedBy="awayTeam")
    Set<TeamPlay> awayTeamPlays;
}
于 2012-12-19T01:19:52.560 回答
0

您的代码没有任何问题。我已经在 TeamPlay 类上使用 @ManyToOne 对其进行了测试,并且效果很好。按预期在 TeamPlay 表上创建连接列。没有什么不寻常的

于 2012-12-18T22:31:48.330 回答