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

    这样就够清楚了吧。

  • 相关阅读:
    论文阅读 | ExtremeNet:Bottom-up Object Detection by Grouping Extreme and Center Points
    论文阅读 | CornerNet:Detecting Objects as Paired Keypoints
    论文阅读 | FPN:Feature Pyramid Networks for Object Detection
    关于字符串 “*****AB**C*D*****” 中前缀、后缀和中间 '*' 的处理
    #include< > 和 #include” ” 的区别
    小朋友排队
    核桃的数量
    操作格子
    字串统计
    关联矩阵
  • 原文地址:https://www.cnblogs.com/my-king/p/4945876.html
Copyright © 2020-2023  润新知