2009.11.24——Hibernate(5) Annotations注解之@joinclumn和mappedby
@joinclumn
@JoinColumn与本书上一章讲述的@Column注释类似,
在使用@JoinColumn注释时,应注意以下几个问题。
l @JoinColumn与@Column标记一样,是用于注释表中的字段的。它的属性与@Column属性有很多相同
之处,这里就不详细讲述。
2 @JoinColumn与@Column相区别的是:@JoinColumn注释的是保存表与表之间关系的字段,它要标注
在实体属性上。而@Column标注的是表中不包含表关系的字段。
3 与@Column标记一样,name属性是用来标识表中所对应的字段的名称。例如customer表中存在字段
addr_id,标识的代码如下所示。
@OneToOne
@JoinColumn(name = "addr_id")
public Address getAddress() {
return address;
}
也就是说name的值,是@joincolun标示的这个属性在数据库中对应的字段名称。
mappedby
mappedBy属性用于双向关联实体时,标注在不保存关系的实体中,基本上相当于 inverse="true"
双向关联后AddressEO 实体的代码如下所示。
@Entity
@Table(name = "address")
public class Address implements java.io.Serializable {
……
private Customer customer;
@OneToOne(mappedBy = "address")//双向关联时就需要这句话,单向则不必
public Customer getCustomer() {
return customer;
}
public void setCustomer(Customer customer) {
this.customer = customer;
}
}
其中,Customer属性也要使用@OneToOne标记,并且使用mappedBy属性来指明所映射的实体关系,它的值为所
关联实体中该属性的名称。
例如本例中mappedBy = "address",address作为Customer实体中的属性存在,如下代码中所示。
@Entity
@Table(name = "customer")
public class Customer implements java.io.Serializable {
private Address address;
@OneToOne(cascade = { CascadeType.ALL })
@JoinColumn(name="address_id")
public Address getAddress() {
return address;
}
}
这样配置后,不仅通过Customer实体能够获得Address实体,也能够通过Address获得Customer实体
mappedby的值,为另一实体中保存本实体实例的属性名。
参考:http://blog.csdn.net/EJB_JPA/archive/2008/05/11/2433291.aspx