[英]JPA Foreign Key OneToMany
我有兩個實體,它們以一對多的關系連接。
public class Book{
@OneToMany(mappedBy = "book")
private List<Page> pages;
}
public class Page{
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "book_id")
public Book book;
}
因此,如果頁面引用了該書,則無法刪除該書。 但是,只要它們引用一本書,我怎樣才能防止頁面被刪除?
我想要一個外鍵約束,只要它們引用任何書,就可以防止刪除頁面對象。
謝謝你的幫助!
我有一個使用@PreRemove 的解決方案。 這樣,如果頁面鏈接到一本書,它將防止頁面被刪除。
BookRelationShipExist:它只是一個你可以創建的異常,你也可以拋出任何其他類型的異常
public class Page{
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "book_id")
public Book book;
@PreRemove
private void preRemove() {
if (book != null) {
throw new BookRelationShipExist();
}
}
}
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.