关闭

Hibernate关联映射-一对一(主外键,单双方向)

标签: hibernate
503人阅读 评论(0) 收藏 举报
分类:

一, 单向外键一对一(many-to-one)
1,主表:Account : (省略get,set方法)
private Integer id;
private String name;
private Address address; //引用从表,
从表:Address(省略get,set方法)
private int id;
private String address;
2,配置文件
在Account.hbm.xml中

    <!-- 通过Many-to-One 添加唯一属性约束,建立一对一的关系  unique 说明是唯一的-->
        <many-to-one name="address" column="address_id" unique="true">
    </many-to-one>

二, 单向主键一对一(one-to-one)
1,主表:IDCard(省略get,set方法)
private Integer id;
private String no;
private Citizen citizen;//引用从表对象
从表:Citizen(省略get,set方法)
private int id;
private String name;
2,配置文件
在IDCard.hbm.xml中,

<id name="id">
            <generator class="foreign">
                <param name="property">citizen</param>
            </generator>
        </id>
    <!--constrained 告诉当前主键,你的值时采用另个表中的主键的值当前主键对于有关系的另一个表来说就是外键。-->
    <one-to-one name="citizen" constrained="true"></one-to-one>

三,双向外键一对一
1,主表:Account : (省略get,set方法)
private Integer id;
private String name;
private Address address; //引用从表,
从表:Address(省略get,set方法)
private int id;
private String address;
private Account account;//引用主表
2,配置文件(在单向的基础上添加)

(1)在Account.hbm.xml中(主)
            <!-- 通过Many-to-One 添加唯一属性约束,建立一对一的关系  unique 说明是唯一的-->
        <many-to-one name="address" column="address_id" unique="true"></many-to-one>

(2)在Address.hbm.xml中(从)

四, 双向主键一对一
1,主表:IDCard(省略get,set方法)
private Integer id;
private String no;
private Citizen citizen;//引用从表对象
从表:Citizen(省略get,set方法)
private int id;
private String name
private IDCard idCard;//引用主表对象
2,配置文件(在单向的基础上添加)
(1)在IDCard.hbm.xml中

        <id name="id">
            <generator class="foreign">
                <param name="property">citizen</param>
            </generator>
        </id>
    <!--constrained 告诉当前主键,你的值时采用另个表中的主键的值当前主键对于有关系的另一个表来说就是外键。-->
    <one-to-one name="citizen" constrained="true"></one-to-one>
(2)在Citizen.hbm.xml中
<!-- 建立一对一关系 -->
        <one-to-one name="idCard" />
0
0

查看评论
* 以上用户言论只代表其个人观点,不代表CSDN网站的观点或立场
    个人资料
    • 访问:11286次
    • 积分:360
    • 等级:
    • 排名:千里之外
    • 原创:25篇
    • 转载:5篇
    • 译文:0篇
    • 评论:4条
    最新评论