zoukankan      html  css  js  c++  java
  • 关于Hibernate(JPA)关联关系加载的默认值

    Hibernate(JPA)中的@OneToOne,@OneToMany,@ManyToOne,@ManyToMany,对于其级联关系即实体类中配置的CascadeType我 们知道有五种value.即 CascadeType.PERSIST,CascadeType.MERGE,CascadeType.REMOVE,CascadeType.REFRESH,CascadeType.ALL,对于其具体含 义,我不在赘述,网上到处都有,这里想说一说CascadeType.ALL,其含义应该是包含前面四种value,为什么要强调四种,因为在我们实际开 发过程中,特别容易遗忘,CascadeType.REFRESH,总认为CascadeType.ALL即代表PERSIST,MERGE,REMOVE,这是在开发过程中 要注意的地方,另外对于@OneToOne,@OneToMany,@ManyToOne,@ManyToMany的fetch默认值如下: @OneToMany,@ManyToMany默认采用LAZY方式加载实体,而@OneToOne,@ManyToOne默认则采用EAGER方式加载。可以好好想 想为什么JPA机制默认会这样安排?个人认为在于这还是应该从效率上来说的,多的一方我们并不能确定其数据量,如果贸然使用EAGER的话, 也许多的一方会有大量数据被加载进来,从而其效率将会严重受到影响,比如我们一个学校和学校的学生是一对多关系,如果国家在统计共有多 少所学校时将学生信息全部EAGER加载进来.......性能堪忧......反过来,如果我们在统计每一个学生的信息时,使用EAGER加载进学校的信息, 由于学校只有一个,所以对性能根本不会有影响,所以我觉得这就是为何@OneToMany默认使用LAZY而@ManyToOne默认只用EARER

    编程改变生活,改变人生
    个人博客:http://blog.5ishuai.com
  • 相关阅读:
    【基础知识七】贝叶斯分类器
    tensorflow入门资料
    机器学习常用开发工具【转】
    SVM的sklearn.svm.SVC实现与类参数
    从线性回归到CNN【转】
    RBF神经网络和BP神经网络的关系
    sklearn安装
    【转】SQL模糊查询
    笔记:XML-解析文档-流机制解析器(SAX、StAX)
    笔记:XML-解析文档-XPath 定位信息
  • 原文地址:https://www.cnblogs.com/shengkejava/p/2652661.html
Copyright © 2011-2022 走看看