本篇内容主要讲解“Hibernate延迟加载机制是什么”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“Hibernate延迟加载机制是什么”吧!
成都创新互联公司长期为近千家客户提供的网站建设服务,团队从业经验10年,关注不同地域、不同群体,并针对不同对象提供差异化的产品和服务;打造开放共赢平台,与合作伙伴共同营造健康的互联网生态环境。为可克达拉企业提供专业的网站建设、做网站,可克达拉网站改版等技术服务。拥有十年丰富建站经验和众多成功案例,为您定制开发。
延迟加载机制是为了避免一些无谓的性能开销而提出来的,所谓延迟加载就是当在真正需要数据的时候,才真正执行数据加载操作。在Hibernate中提供了对实体对象的延迟加载以及对集合的延迟加载,另外在Hibernate3中还提供了对属性的延迟加载。下面我们就介绍Hibernate属性延迟加载。
Hibernate属性延迟加载
在Hibernate3中,引入了一种新的特性——Hibernate属性延迟加载,这个机制又为获取高性能查询提供了有力的工具。在前面我们讲大数据对象读取时,在User对象中有一个resume字段,该字段是一个 java.sql.Clob类型,包含了用户的简历信息,当我们加载该对象时,我们不得不每一次都要加载这个字段,而不论我们是否真的需要它,而且这种大数据对象的读取本身会带来很大的性能开销。在Hibernate2中,我们只有通过我们前面讲过的面性能的粒度细分,来分解User类,来解决这个问题(请参照那一节的论述),但是在Hibernate3中,我们可以通过Hibernate属性延迟加载机制,来使我们获得只有当我们真正需要操作这个字段时,才去读取这个字段数据的能力,为此我们必须如下配置我们的实体类:
通过对
String sql=”from User user where user.name=’zx’ ”; Query query=session.createQuery(sql) List list=query.list(); for(int i=0;i当执行到第二行时,会生成类似如下的SQL语句:
Select id,age,name from user where name=’zx’;这时Hibernate会检索User实体中所有非延迟加载属性对应的字段数据,当执行到第七行时,会生成类似如下的SQL语句:
Select resume from user where id=’1’;这时会发起对resume字段数据真正的读取操作
到此,相信大家对“Hibernate延迟加载机制是什么”有了更深的了解,不妨来实际操作一番吧!这里是创新互联网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!
文章名称:Hibernate延迟加载机制是什么
文章分享:http://bzwzjz.com/article/pcppjj.html