zoukankan      html  css  js  c++  java
  • hibernate一对多关联映射

    一、hibernate一对多关联映射(单向Classes--->Student)

    一对多关联映射和多对一关联映射映射原理是一致的,都是在多的一端加入一个外键,指向一的一端

    它们的区别在于维护的关系不同:  

      * 多对一维护的关系是:多指向一的关系,有了此关系,在加载多的时候可以将一加载上来  

      * 一对多维护的关系是:一指向多的关系,有了此关系,在加载一的时候可以将多加载上来   在一一端维护关系存在缺陷:  

      * 因为多的一端Student不知道Classes的存在(也就是Student没有维护与Classes的关系)  所以在保存Student的时候关系字段classesid是为null的,如果将该关系字段设置为非空,则  将无法保存数据  

      * 另外因为Student不维护关系,而Classes维护关系,Classes就会发出多余的update语句,保证  Classes和Student有关系,这样加载Classes的时候才可以把该Classes对应的学生加载上来      

    二、hibernate一对多关联映射(双向Classes<--->Student)

    采用一对多双向关联映射的目的主要是为了主要是为了解决一对多单向关联的缺陷 而不是需求驱动的

    一对多双向关联的映射方式:

       * 在一的一端的集合上采用<key>标签,在多的一端加入一个外键

       * 在多的一端采用<many-to-one>标签

         !!!注意:<key>标签和<many-to-one>标签加入的字段保持一直,否则会产生数据混乱

    inverse属性:

       * inverse属性可以用在一对多和多对多双向关联上,inverse属性默认为false,为  false表示本端可以维护关系,

        如果inverse为true,则本端不能维护关系,会交给另一端  维护关系,本端失效。    

          所以一对多关联映射我们通常在多的一端维护关系,让一的一端失效,所以设置为inverse为true   inverse和cascade

       * inverse是控制方向上的反转,只影响存储

       * cascade是操作上的连锁反映

  • 相关阅读:
    迭代器和生成器
    案例:复制大文件
    案例:使用seek倒查获取日志文件的最后一行
    Leetcode165. Compare Version Numbers比较版本号
    Leetcode137. Single Number II只出现一次的数字2
    Leetcode129. Sum Root to Leaf Numbers求根到叶子节点数字之和
    Leetcode116. Populating Next Right Pointers in Each Node填充同一层的兄弟节点
    Leetcode114. Flatten Binary Tree to Linked List二叉树展开为链表
    Leetcode113. Path Sum II路径总和2
    C++stl中vector的几种常用构造方法
  • 原文地址:https://www.cnblogs.com/fanszone/p/3072455.html
Copyright © 2011-2022 走看看