关联映射文件中<class>标签中的lazy(懒加载)属性

Lazy(懒加载):只有在正真使用该对象时,才会创建这个对象

Hibernate中的lazy(懒加载):只有我们在正真使用时,它才会发出SQL语句,给我们去查询,如果不使用对象则不会发SQL语句进行查询。

Hibernate中lazy(懒加载)的实现:

采用了第三方组件的库,这个库叫cglib.jar(比较流行),这个库对我们的类生成代理类(JDK的动态代理,只能对JDK中实现了接口的类进行代理),代理可以控制源对象并且可以对源对象的功能进行增强,而cglib.jar可以对类进行代理(cglib对我们的类进行继承,生成一个子类,这个子类作为代理类返回给你)。

只有你正真代理类的方法,则会查看你有没有加载目标对象,如果没有则会加载目标对象。

Lazy(懒加载)在hibernate何处使用:

1、<class>标签上,可以取值:true/false,(默认值为:true)

2、<property>标签上,可以取值:true/false,需要类增强工具

3、<set>、<list>集合上,可以取值:true/false/extra,(默认值为:true)

4、<one-to-one>、<many-to-one>单端关联上,可以取值:false/proxy/noproxy

Session.load()方法支持lazy,而session.get()不支持lazy;

Hibernate的lazy生效期:

生效期和session一样的,session关闭,lazy失效

hibernate支持lazy策略只有在session打开状态下有效。

<class>标签上,可以取值:true/false,(默认值为:true):

实例一:设置<class标签上的lazy=true(默认)

@Test
public void LazyTest() {
session = HibernateUtil.getSession();
tx = session.beginTransaction(); // 执行此语并不会发SQL语句,只是返回一个代理类
Group group = (Group) session.load(Group.class, 1); // 不会发SQL语句,使用上面输入的1值
System.out.println("group.id=" + group.getId()); // 此处使用对象,会发出SQL语句
System.out.println("group.name=" + group.getName()); // 提交事务
tx.commit();
}

输出:

group.id=1
Hibernate: select group0_.id as id1_1_0_, group0_.name as name2_1_0_ from t_group group0_ where group0_.id=?

设置<class标签上的lazy=true(默认)

@Test
public void LazyTest1(){
Session session = null;
Transaction tx = null;
Group group = null; try {
session = HibernateUtil.getSession();
tx = session.beginTransaction(); group =(Group)session.load(Group.class, 1); System.out.println("group.name=" + group.getName()); //提交事务
tx.commit();
} catch (Exception e) {
e.printStackTrace();
tx.rollback();
} finally {
HibernateUtil.closeSession(session);
} //不能正确输出,抛出了LazyInitalizationException异常,因为session已经关闭
//hibernate支持lazy策略只有在session打开状态下有效。
System.out.println("group.name=" + group.getName());
}

关联映射文件中集合标签中的lazy(懒加载)属性

<set>、<list>集合上,可以取值:true/false/extra,(默认值为:true)

实例一:(集合上的lazy=true(默认))

@Test
public void LazyTest2() { session = HibernateUtil.getSession();
tx = session.beginTransaction();
// 不会发出SQL语句
Classes classes = (Classes) session.load(Classes.class, 1);
// 发出SQL语句,因为在使用对象
System.out.println("classes.name=" + classes.getName()); // 不会发SQL语句,只会返回一个代理类,因为没有使用对象
Set<Student> students = classes.getStudents(); // 会发出SQL语句,因为使用了对象
for (Iterator<Student> iter = students.iterator(); iter.hasNext();) {
Student student = iter.next();
System.out.println(student.getName());
} // 提交事务
tx.commit();
}

实例二:集合上的lazy=true(默认)

session = HibernateUtils.getSession();
tx = session.beginTransaction(); //不会发出SQL语句
Classes classes = (Classes)session.load(Classes.class, 1);
//发出SQL语句,因为在使用对象
System.out.println("classes.name=" + classes.getName()); //不会发SQL语句,只会返回一个代理类,因为没有使用对象
Set<Student> students = classes.getStudents(); //会发出SQL语句,发出查询全部数据的SQL,效率不高
System.out.println("student.count=" + students.size()); //提交事务
tx.commit();

实例三:集合上的lazy=false,其它保持默认

//不会发出SQL语句,因为只设置了集合上的lazy为false,其它保持默认
Classes classes = (Classes)session.load(Classes.class, 1);
//发出两条SQL语句,分别加载classes和student
//并且把集合中的数据也加载上来(虽然并没有使用集合中的对象),因为设置了集合的lazy=false
System.out.println("classes.name=" + classes.getName()); //不会发SQL语句,因为已经在前面加载了数据
Set<Student> students = classes.getStudents(); //会发出SQL语句,因为已经在前面加载了数据
for (Iterator<Student> iter = students.iterator();iter.hasNext();){
Student student = iter.next();
System.out.println(student.getName());
}

实例四:集合上的lazy=false,其它保持默认

//不会发出SQL语句
Classes classes = (Classes)session.load(Classes.class, 1);
//发出两条SQL语句,分别加载classes和student
//并且把集合中的数据也加载上来(虽然并没有使用集合中的对象),因为设置了集合的lazy=false
System.out.println("classes.name=" + classes.getName()); //不会发SQL语句,因为已经在前面加载了数据
Set<Student> students = classes.getStudents(); //不会发SQL语句,因为已经在前面加载了数据
System.out.println("student.count=" + students.size());

实例五:设置集合上lazy=extra,其它默认

session = HibernateUtils.getSession();
tx = session.beginTransaction(); //不会发出SQL语句
Classes classes = (Classes)session.load(Classes.class, 1); //会发出SQL语句
System.out.println("classes.name=" + classes.getName()); //不会发出SQL语句,只返回代理类
Set<Student> students = classes.getStudents(); //会发出SQL语句
for (Iterator<Student> iter = students.iterator();iter.hasNext();){
Student student = iter.next();
System.out.println(student.getName());
}

实例六:设置集合上lazy=extra,其它默认

session = HibernateUtils.getSession();
tx = session.beginTransaction(); //不会发出SQL语句
Classes classes = (Classes)session.load(Classes.class, 1);
//发出两条SQL语句
System.out.println("classes.name=" + classes.getName()); //不会发出SQL语句
Set<Student> students = classes.getStudents(); //发出SQL语句,发出一条比较智能的SQL语句(select count(id) form t_student where classesid=?)
System.out.println("student.count=" + students.size()); //提交事务
tx.commit();

<one-to-one>、<many-to-one>单端关联上的lazy(懒加载)属性

Ø <one-to-one>、<many-to-one>单端关联上,可以取值:false/proxy/noproxy(false/代理/不代理)

实例一:所有lazy属性默认(支持懒加载)

session = HibernateUtils.getSession();
tx = session.beginTransaction(); //不发出SQL语句,支持lazy(懒加载)
User user = (User) session.load(User.class, 3);
//发出SQL语句,只加载普通属性,集合中的数据不会加载
System.out.println("user.name=" + user.getName()); //不会发出SQL语句,只返回代理类
Group group = user.getGroup();
//发出SQL语句,因为现在真正使用对象
System.out.println("group.name=" + group.getName());
tx.commit();

实例二:将<many-to-one>中的lazy设置为false,其它默认

session = HibernateUtils.getSession();
tx = session.beginTransaction(); //不会发出SQL
User user = (User) session.load(User.class, 3);
//会发出SQL,发出两条SQL,分别是User和组
//因为<many-to-one>中的lazy=false,则会加载Group
System.out.println("user.name=" + user.getName()); //不会发出,已经在上面加载了数据
Group group = user.getGroup();
//不会发出,已经在上面加载了数据
System.out.println("group.name=" + group.getName());
tx.commit();

实例三:将<class>中的lazy设置为false,其它默认

session = HibernateUtils.getSession();
tx = session.beginTransaction(); //会发出SQL,因为<class>中的lazy=false
User user = (User) session.load(User.class, 3);
//不会发出SQL,已经在上面加载了
System.out.println("user.name=" + user.getName()); //不会发出,因为<class>标签上的lazy只对普通属性的影响
//<class>标签上的lazy不会影响到单端关联上的lazy特性
Group group = user.getGroup();
//会发出,因为开始使用对象
System.out.println("group.name=" + group.getName()); tx.commit();

hibernate--lazy(懒加载)属性的更多相关文章

  1. 018 关联映射文件中<class>标签中的lazy(懒加载)属性

    Lazy(懒加载): 只有在正真使用该对象时,才会创建这个对象 Hibernate中的lazy(懒加载): 只有我们在正真使用时,它才会发出SQL语句,给我们去查询,如果不使用对象则不会发SQL语句进 ...

  2. 020 <one-to-one>、<many-to-one>单端关联上的lazy(懒加载)属性

    <one-to-one>.<many-to-one>单端关联上,可以取值:false/proxy/noproxy(false/代理/不代理) 实例一:所有lazy属性默认(支持 ...

  3. 019 关联映射文件中集合标签中的lazy(懒加载)属性

    <set>.<list>集合上,可以取值:true/false/extra,(默认值为:true) 实例一:(集合上的lazy=true(默认))class默认lazy=tru ...

  4. hibernate的懒加载问题

    产生原因: 当使用hibernate查询一个对象的时候,如果Session关闭,再调用该对象关联的集合或者对象的时候,会产生懒加载异常! 解决方案: 方案一: 在Session关闭之前,查询对象关联的 ...

  5. Hibernate的懒加载session丢失解决方法

    在web.xml加入spring提供的过滤器,延长session的生命周期 <!--Hibernate的懒加载session丢失解决方法 --> <filter> <fi ...

  6. hibernate 中 fetch=FetchType.LAZY 懒加载失败处理

    对这种懒加载问题,最后的做法是利用Spring提供的一个针对Hibernate的一个支持类,其主要意思是在发起一个页面请求时打开Hibernate的Session,一直保持这个Session,使得Hi ...

  7. hibernate的懒加载

    WHY? WHAT? HOW? 所谓懒加载(lazy)就是延时加载,延迟加载.即不是不加载,而是在需要的时候才加载. 什么时候用懒加载呢,我只能回答要用懒加载的时候就用懒加载. 至于为什么要用懒加载呢 ...

  8. Hibernate @OneToOne懒加载实现解决方案

    在hibernate注解(三)中,我提高过一对一(@OneToOne)懒加载失效的问题.虽然给出了解决方法,但并没有给出完整的解决方案.今天我专门针对该问题进行讨论.至于懒加载失效的原因,在之前的文章 ...

  9. hibernate+spring mvc, 解决hibernate 对象懒加载 json序列化问题

    引用地址 在使用Spring MVC时,@ResponseBody 注解的方法返回一个有懒加载对象的时候出现了异常,以登录为例: @RequestMapping("login") ...

随机推荐

  1. NOIP2015-stone(二分答案)

    这道题在考试时二分答案写炸了,结果得了20分.....同学有用贪心写的(对,贪心!!)都得了30,我感到了深深的恶意.这段时间在忙转语言,现在重新整理一下NOIP的题. 题目来源:vijos 题目如下 ...

  2. KVM通过qemu实现USB重定向

    KVM是通过qemu来支持USB设备的,可以在启动的时候就指定需要连接的USB设备,也可以系统启动后动态的添加删除.通过qemu的help可知,使用qemu的usb_add host:xxx:xxx来 ...

  3. XCODE真机调试设备连接一直忙碌如何处理

    只是还没反应过来 等一会就行了

  4. Android 自定义Toast,不使用系统Toast

    效果图: 创建Toast类 package com.example.messageboxtest; import android.app.Activity; import android.conten ...

  5. Python random模块 例子

    最近用到随机数,就查询资料总结了一下Python random模块(获取随机数)常用方法和使用例子. 1.random.random  random.random()用于生成一个0到1的随机符点数: ...

  6. word小技巧

    如何将英文和数字替换为times new romans 1,点击替换(ctrl+H) .2,在查找内容中输入”([A-Z0-9])“(不包括引号,但包括小括号),这是替换所有大写字母和数字,如果还想替 ...

  7. Codeforces Round #343 (Div. 2) C. Famil Door and Brackets

    题目链接: http://codeforces.com/contest/629/problem/C 题意: 长度为n的括号,已经知道的部分的长度为m,现在其前面和后面补充‘(',或')',使得其长度为 ...

  8. URAL 1297 Palindrome 最长回文子串

    POJ上的,ZOJ上的OJ的最长回文子串数据量太大,用后缀数组的方法非常吃力,所以只能挑个数据量小点的试下,真要做可能还是得用manacher.贴一下代码 两个小错,一个是没弄懂string类的sub ...

  9. 解决 Ubuntu 开机 Waiting for 60 seconds more for network configuration

    sudo vim /etc/network/interfaces, 将该文件的内容修改为如下:(也就是说删掉其他的什么auto eth0.auto wlan0) auto lo iface lo in ...

  10. ubuntu 13.10 64bit装BeyondCompare

    1. Beyond Compare官网下载amd-64位的,安装失败,依赖于ia32-libs,但是这个文件已经不在源里了: 2. 官网下载tar.gz源码包,解压安装失败: 3. 直接装32位的,可 ...