摘要: 在HQL语句中使用抓取连接查询,通过写一条left join fetch 语句把相关联的两个实体的数据一次性从数据库中加载上来。这样可以在特定情况下(同时需要使用到这两个实体的数据)减少SQL的数量来提高查询效率。通过配置“抓取策略”来直接影响session的get()和load()方法的查询效果。1.单端关联<many-to-one><onr-to-one>上的抓取策略。可以给单端关联的映射元素添加fetch属性。fetch属性有2个可选值.select:作为默认值,它的策略是当需要使用到关联对象的数据时,另外单独发送一条select语句抓取当前对象的关联对象的数据。 阅读全文
posted @ 2013-01-04 15:38 流-星-追-月 阅读(207) 评论(0) 推荐(0) 编辑
摘要: 为了进一步优化Hibernate的性能,可以使用:延迟加载技术、管理数据抓取策略、进行缓存管理 等方面考虑来提高Hibernate的性能。1. 延迟加载(load)延迟加载(load)是Hibernate为提高程序执行效率而提供的一种机制,即只有真正使用该对象的数据时才会创建。延迟加载的过程:通过代理(Proxy)机制来实现延迟加载。Hibernate从数据库获取某一个对象数据时、获取某一个对象的集合属性值时,或获取某一个对象所关联的另一个对象时,由于没有使用该对象的数据(除标识符外),Hibernate并不从数据库加载真正的数据,而只是为该对象创建一个代理对象来代表这个对象,这个对象上的所有 阅读全文
posted @ 2013-01-04 15:31 流-星-追-月 阅读(1800) 评论(0) 推荐(0) 编辑
摘要: 深入Hibernate一、Hibernate数据查询HQL:Hibernate查询语言,它是Hibernate提供的一种面向对象的查询语言。(1)在查询语句中设定各种查询条件(2)支持动态绑定参数(3)支持投影查询、分页查询、连接查询、分组查询,子查询(4) 内置了一些聚集函数Hibernate中的Query接口就是专门用来执行HQL语句的查询接口。1.创建查询对象Query query=session.createQuery(“from Dept”);2.执行查询列出结果1)列出所有的结果List<Dept> depts=query.list();for(Dept dept:de 阅读全文
posted @ 2013-01-04 15:25 流-星-追-月 阅读(186) 评论(0) 推荐(0) 编辑