1. 程式人生 > >Hibernate 註解對映

Hibernate 註解對映

工作中遇到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