Hibernate检索策略(抓取策略)(Hibernate检索优化)
一、查询方法中get方法采用策略是立即检索,而load方法采用策略是延迟检索,延迟检索是在使用数据时才发送SQL语句加载数据
获取延迟加载数据方式:1、使用的时候,如果Customer c=session.load(Customer.class,1);//加载id为1的客户,此时是延迟加载,返回的是代理对象,当使用的时候加载数据,如c.getName();
2、调用Hibernate.initialize(c);方法,初始化对象,也可加载到数据
二、类级别检索策略
包括立即检索和延迟检索,即使用get和load方法,而Query查询的数据属于类级别检索中的立即检索
可以在hbm.xml文件中的class节点配置lazy="false",这样load方法也变成立即检索了,和get方法一样了
三、关联级别检索策略
1、多对多与一对多,都是先得到一个再检索另一个,所以这两种情况一样
在hbm.xml文件中set节点上设置fetch和lazy两个属性
fetch可取值:join select subselect fetch代表检索时语句方式
lazy可取值:true false extra lazy代表是否延迟
(1)、如果fetch为join,则lazy失效,采用迫切左外连接
(2)、fetch为select时,将生成多条简单SQL语句
lazy=false,立即检索
lazy=true,延迟检索
lazy=extra,加强延迟检索(极其懒惰检索),比如查询关联类集合条数,则发送select count(*) from table
(3)、fetch为subselect时,将生成子查询SQL语句,这时查询方法要用query.list().get
使用Query查询数据时,自己编写hql语句,则fetch=join无效,关联集合将根据lazy设置进行加载
2、一对一和多对一情形一样,都是由一个得到另一个
在hbm.xml文件中many-to-one节点上设置fetch和lazy两个属性
fetch可取:join select
lazy可取:false proxy no-proxy
(1)、如果fetch为join,则lazy失效,采用迫切左外连接
(2)、fetch为select时,将生成多条简单SQL语句
lazy=false,立即检索
lazy=proxy,采用的检索方式为对方类级别检索方式,如订单查询客户是一对多,此时要采用customer.hbm.xml配置中class上配置的lazy检索方式
使用Query查询数据时,自己编写hql语句,则fetch=join无效,关联集合将根据lazy设置进行加载
结论:开发中能延迟则延迟,必须立即才立即(优化方案)
四、批量检索,解决N+1查询问题
N+1问题:如查询所有客户订单,首先查询出所有客户,而后根据每个客户id分别去查找订单,导致N+1问题
其实质就是先查询所有客户,得到客户id,然后通过SQL的in语句来查询订单中客户id in(前门查出的id)中
解决方案:在customer.hbm.xml文件中set节点设置batch-size属性,即,分批提取数据。如果共4个客户,设置值大于等于4会有两条SQL语句发出;如果设置小于4,则至少会有三条语句发出
如果是通过订单查询客户解决N+1问题,而订单中没有set节点,就在客户hbm.xml配置文件的class节点配置batch-size(是查询客户,所以在客户class节点配置)
Hibernate检索策略(抓取策略)(Hibernate检索优化)的更多相关文章
- Hibernate(十四)抓取策略
抓取策略: 抓取策略是当应用程序需要在(Hibernate实体对象图的)关联关系间进行导航的时候,Hibernate如何获取关联对象的策略.Hibernate的抓取策略是Hibernate提升性能的一 ...
- hibernate 延迟加载和抓取策略
一.延迟加载 1.简单查询get,load 针对对象本身延迟或即时 当使用load方法来得到一个对象时,此时hibernate会使用延迟加载的机制来加载这个对象,即:当我们使用session.load ...
- Hibernate学习---第十一节:Hibernate之数据抓取策略&批量抓取
1.hibernate 也可以通过标准的 SQL 进行查询 (1).将SQL查询写在 java 代码中 /** * 查询所有 */ @Test public void testQuery(){ // ...
- 【转】hibernate延迟加载和抓取策略
一.延迟加载 1.简单查询get,load 针对对象本身延迟或即时 当使用load方法来得到一个对象时,此时hibernate会使用延迟加载的机制来加载这个对象,即:当我们使用session.load ...
- 【Hibernate学习】 —— 抓取策略(注解方式)
当应用程序须要在关联关系间进行导航的时候.hibernate怎样获取关联对象的策略. 抓取策略的方式: FetchType.LAZY:懒载入.载入一个实体时.定义懒载入的属性不会立即从数据库中载入. ...
- hibernate检索策略(抓取策略)
检索策略 类级别检索 默认检索策略:默认延迟加载, 可以使用lazy属性来进行改变. session.get(clazz,object)默认立即加载 @Test //测试左外连接查询 public v ...
- Hibernate查询方式&抓取策略
Hibernate的查询方式 1.OID查询 hibernate根据对象的OID(主键)进行检索 使用get方法 Customer customer=session.get(Customer.clas ...
- 【Hibernate 8】Hibernate的调优方法:抓取策略
在上一篇博客中,介绍了Hibernate的缓存机制.合理的配置缓存,可以极大程度上优化Hibernate的性能.这篇博客,介绍另外一个调优方式:抓取策略. 一.什么是抓取策略 抓取策略(fetchin ...
- Hibernate中的多表查询及抓取策略
1.Hibernate中的多表查询 1.1SQL中的多表查询 [交叉连接] select * from A,B; [内连接] 显示内连接:inner join(inner 可以省略) Select * ...
- Hibernate的抓取策略(优化)
延迟加载的概述 什么是延迟加载 延迟加载:lazy(懒加载).执行到该行代码的时候,不会发送语句去进行查询,在真正使用这个对象的属性的时候才会发送SQL语句进行查询. 延迟加载的分类 l 类级别的延 ...
随机推荐
- ajax读取文本内容(此处的txt文件和html文件处于同级目录)
<!DOCTYPE html> <html> <head> <meta charset="UTF-8" /> <style&g ...
- OAF中的面包屑(breadcrumbs)始无法显示(转)
原文地址:OAF中的面包屑(breadcrumbs)始无法显示 OAF中面包屑是一种重要的导航工具.可以提示用户抵达当前页面的路径,也可以方便的切换到之前的节点. 开始做面包屑开发的时候发现面包屑总是 ...
- 基于Html5的移动端开发框架的研究
下面统计信息部分来自网络,不代表个人观点.请大家参考. 基于Html5移动端开发框架调查 序号 框架 简介 优点 缺 ...
- python 反模式
不使用 pythonic 的循环: l = [1,2,3] #Bad for i in range(0,len(list)): le = l[i] print(i,le) #Good for i,le ...
- timeSeries db之:使用Metrics监控应用程序的性能 (zz)
在编写应用程序的时候,通常会记录日志以便事后分析,在很多情况下是产生了问题之后,再去查看日志,是一种事后的静态分析.在很多时候,我们可能需要了解整个系统在当前,或者某一时刻运行的情况,比如当前系统中对 ...
- [MetaHook] Load TGA texture to OpenGL
This function load a *.tga texture file and convert to OpenGL pixel format, uncompress only. #pragma ...
- 信息安全系统设计基础实验四 20135210&20135218
北京电子科技学院(BESTI) 实 验 报 告 课程:信息安全系统设计基础 班级: 1352 姓名:程涵,姬梦馨 学号:20135210,20135218 ...
- 关于 iOS 10 中 ATS / HTTPS /2017 问题
本文于 2016 年 11 月 28 日按照 Apple 最新的文档和 Xcode 8 中的表现进行了部分更新. WWDC 15 提出的 ATS (App Transport Security) 是 ...
- 中国IT 未来何在
许久之前,已对国内IT业的一些问题颇有看法,而今又恰逢360与AV-C的纠缠,实在忍不住要发发牢骚.IT在中国,发展不过二十来年,却以迅雷之速横扫各个领域,令人感叹,此成就是不可否认的:然而,发展 ...
- JS的十大经典算法排序
引子 有句话怎么说来着: 雷锋推倒雷峰塔,Java implements JavaScript. 当年,想凭借抱Java大腿火一把而不惜把自己名字给改了的JavaScript(原名LiveScript ...