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

网站上各种搜索,都是一些清晰或者不清晰的例子,但是用下来一是确实不给力,二是完全不知道所以然。

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

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

就以比较普遍的Person和Address为例。

新建表t_person: person_id,person_name.

新建表t_address:address_id,person_id.

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

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

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

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

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

<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”的意思是,级联所有操作,关于这个属性更详细的资料自己查去。

这样就够清楚了吧。

原文地址:https://www.cnblogs.com/my-king/p/4945876.html