Hibernate 註解對映
阿新 • • 發佈:2018-12-19
工作中遇到hibernate對映的一些問題,這裡總結一下
(特別是測試時,許多資料並不能有效關聯。所以@NotFound 很重要)
一,假設有2張表user,company
我們知道,一個使用者屬於一個公司。那麼我們這麼建立Model
//使用者 public class User { private int id; private String name; private int companyid //sub table private Company company; @Where(clause="IsValid=1") @OneToOne(fetch= FetchType.EAGER,optional = true) @NotFound(action= NotFoundAction.IGNORE) @JoinColumn(name = "companyid", referencedColumnName = "companyid",insertable = false, updatable = false) public Company getCompany() { return company; } public void setCompany(Company company) { this.company = company; } } //公司 public class Company { private int companyid; private int isValid; //是否有效 }
二 , 解釋一下
@Where(clause="IsValid=1") 設定只查詢IsValid=1的資訊
@OneToOne(fetch= FetchType.EAGER,optional = true) FetchType.EAGER 及時載入,optional = true 是否必須有值
@NotFound(action= NotFoundAction.IGNORE) 忽略沒有關聯的外來鍵
@JoinColumn(name = "inboundOrderUUID", referencedColumnName = "inboundOrderUUID",insertable = false, updatable = false) name:本類的關聯id referencedColumnName:關聯項的id