1

我有两张桌子:AccountsMails

来自 Accounts 的 1 位用户可以有一些邮件(1:M 认证)。

  • 当用户删除他的个人资料(来自Accounts)时,hibernate 应该删除该用户的所有邮件(来自Mails)。Accounts有 id (PK) 和其他列。Mails有 id(PK)、user_id(FK: user_id -> Accounts.id) 等列。

如何在 Hibernate(或 JPA)上实现上述类型的实现?

我的实体类如下:

//Accounts class
@OneToMany(mappedBy = "accounts", cascade = CascadeType.ALL, orphanRemoval = true)
private Set<Mails> mails;

//Mails class
@ManyToOne
@JoinColumn(name="user_id" , referencedColumnName="id", insertable=false, updatable=false)
private Accounts accounts;

但是当我编辑或删除一些父行时,hibernate 说:无法删除或更新父行:外键约束失败。那么我到底在哪里犯了错误?


更新

当我们执行 SQL 或 HQL 查询时会发生此错误,但事实并非如此。我们应该使用 entitymanager.remove 或 entitymanager.merge 方法。我的实体类是有效的。

4

1 回答 1

1

看来您在帐户和邮件之间有双向关系。在帐户类中,您必须使用一些想法,例如:

@OneToMany(cascade = CascadeType.ALL, orphanRemoval = true, mappedBy = "accounts")  
private Set<Mails> mails;

双向需要属性 mappedby。提示:在我看来,如果真的有必要,你应该只使用双向关系。

于 2013-06-19T08:11:41.603 回答