2009.11.24——Hibernate(5) Annotations注解之@joinclumn和mappedby

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

你可能感兴趣的:(Hibernate,.net,ejb,Blog,jpa)