hibernate框架的查询优化(二十三)

来源:互联网 发布:管家婆进销存软件 价格 编辑:程序博客网 时间:2024/06/04 20:02

一、延迟加载

延迟加载先获取到代理对象,当真正使用到该对象中的属性的时候,才会发送SQL语句,是Hibernate框架提升性能的方式

1.1 类级别的延迟加载

Session对象的load方法默认就是延迟加载

Customer c = session.load(Customer.class, 1L);没有发送SQL语句,当使用该对象的属性时,才发送SQL语句

1.1.1 session.get()不采用延迟加载

@Testpublic void run1() {Session session = HibernateUtils.getCurrentSession();Transaction tx = session.beginTransaction();Customer c1 = session.get(Customer.class, 1L);System.out.println("=======================");System.out.println(c1.getCust_name());tx.commit();}

程序执行完get()方法就发出了SQL语句

1.1.2 session.load()采用延迟加载


程序执行完load()方法,未发出sql语句


调用对象方法时才去查询数据库

1.1.3 关闭load的延迟加载

使类级别的延迟加载失效
 在<class>标签上配置lazy=”false”
 Hibernate.initialize(Object proxy);

1.1.3.1 配置lazy


再看程序运行效果


先出现sql,后出现=====,说明,没有延迟加载

1.1.3.2 initialize


1.2 关联级别的延迟加载

关联级别的延迟加载(查询某个客户,当查看该客户下的所有联系人是是否是延迟加载)
默认是延迟加载

/** * 关联级别的延迟加载  * 说的是客户下的联系人的集合 */@Testpublic void run3() {Session session = HibernateUtils.getCurrentSession();Transaction tx = session.beginTransaction();// 先查1号客户Customer c1 = session.get(Customer.class, 1L);System.out.println("=======================");// 看客户下所有的联系人System.out.println(c1.getLinkmans().size());tx.commit();}

等号前有sql,是查询customer的,等号后有sql,是查询linkman的,说明,默认情况下采用了延迟加载。

对于关联查询策略,请看下一篇。


原创粉丝点击