Hibernate一对一双向关联(外键)

网站上各类搜索,都是一些清晰或者不清晰的例子,可是用下来一是确实不给力,二是彻底不知道因此然。java

后来终于在书中查到了就在这里记一下。fetch

首先要说明,这里只解释双向一对一只有一个表里面有外键的状况。网站

就以比较广泛的Person和Address为例。spa

新建表t_person: person_id,person_name.code

新建表t_address:address_id,person_id.xml

新建Person.java类里面有属性:personId, personName, address;blog

新建Address.java类里面有属性:addressId,person;class

重点来了,在Person.hbm.xml里面这么配置配置

<one-to-one name="address" class="com.bean.Address" cascade="all" property-ref="person"/>

而在Address.hbm.xml里面这么配置select

<many-to-one name="person" class="com.bean.Person" fetch="select" unique="true" column="person_id"/>

咱们能够看到一个是one-to-one一个是many-to-one的unique。

分清楚这两个很重要,many-to-one用在保存外键的表,也就是说Address表,one-to-one用在没有保存外键的表,也就是person表.

而Address.hbm.xml这个配置的意思是:在Address.java里面有一个person属性,它是一个外键,而且对应的列是t_address表里面的person_id. unique="true" 是说这里的关系是一对一的。

Person.hbm.xml 的配置文件意思是:我是一个主表,我里面有一个addresss的属性,跟t_address表里面的person_id是关联再一块儿 的。

cascade=“all”的意思是,级联全部操做,关于这个属性更详细的资料本身查去。

这样就够清楚了吧。

相关文章
相关标签/搜索