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

    这样就够清楚了吧。

  • 相关阅读:
    echarts中图表过于靠左或靠右的情况解决办法。
    C#语法糖大汇总【转发】
    近期对于windows服务的理解
    解决echarts中X轴文字过长的问题。【转】
    两个页面之间通过后台处理,调用父窗体方法。
    docker
    docker php
    webpack
    jwt 解密
    阿里云服务器 ECS Linux 主机删除文件后磁盘空间显示不变(转载https://www.zhanqunfuwuqi.com/archives/5293)
  • 原文地址:https://www.cnblogs.com/my-king/p/4945876.html
Copyright © 2011-2022 走看看