zoukankan      html  css  js  c++  java
  • hibernate关联关系笔记

    Hibernate关联关系笔记

    • 单向N:1

        *  有连接表:在N方使用<join>/<many-to-one>。1方无需配置与之关联的持久化类。

        *  没有连接表:在N方使用<many-to-one>。1方无需配置与之关联的持久化类。

    • 单向1:N

        *  有连接表: 在1方使用<set>/<many-to-many>,在many-to-many中将unique属性设置为true。 N方无需配置与之关联的持久化类。

        *  没有连接表:在1方使用<set>/<one-to-many>。N方无需配置与之关联的持久化类。

        注:cascade属性在<set>上配置

    • 双向1:N

        *  有连接表:1方使用<set>/<many-to-many>并设置<many-to-many>的unique参数为true。N方使用<join>/<many-to-one>

        *  没有连接表:1方使用<set>/<one-to-many>。N方使用<many-to-one>

        注:只能在1的一方使用inverse放弃控制权,N的一方无法放弃控制权,因为没有inverse属性。

    • 单向N:N

        控制端使用<set>/<many-to-many>

    • 双向N:N

        两边都使用<set>/<many-to-many>

    • 单向1:1

        *  基于外键:控制端使用<many-to-one>,并设置<many-to-one>的unique属性为true。

        *  基于主键:控制端设置ID生成策略为foreign,并使用<one-to-one>标签。

        *  基于连接表:控制端使用<join>/<many-to-one>,并设置<many-to-one>的unique属性为true

    • 双向1:1

        *  基于外键:一方使用<many-to-one>并设置其unique参数为true。另一方使用<one-to-one>

        *  基于主键:一方设置ID生成策略为foreign,并使用<one-to-one>标签。另一方只使用<one-to-one>标签。

        *  基于连接表:两边都使用<join>/<many-to-one>。并都设置<join>下的<key>unique属性和<many-to-one>的unique属性为true。而且两边需要有一边设置inverse参数为true,即放弃控制权。

  • 相关阅读:
    mysql视图产生派生表无法优化案例
    根据.frm .ibd文件恢复表
    binlog内容时间乱序问题排查
    mysql官方的测试数据库employees超30万的数据,安装方法介绍
    数据库大量Waiting for table flush 状态SQL问题排查
    mysql搭建从库并配置ssl
    MySQL lOAD DATA详解
    redis eval
    aws-rds for mysql 5.7.34时间点恢复数据
    MySQL 如何处理监听连接的
  • 原文地址:https://www.cnblogs.com/caiyao/p/4810359.html
Copyright © 2011-2022 走看看