Hibernate -- lazy加载

hibernate类级别懒加载:

lazy:true(默认)

//类级别懒加载
//load方法
//class lazy属性
//默认值:true load获得时,会返回代理对象,不查询数据库,使用时才查询
public void fun1() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
Customer load = (Customer) session.load(Customer.class, 17);
System.out.println("----------------sql语句未发送");
System.out.println(load.getName());
//--------------------------------------
session.getTransaction().commit();
session.close();
}

lazy :false

//类级别懒加载
//load方法
//class lazy属性
//默认值:false load方法执行就会发送sql语句,和get方法一致
public void fun2() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
Customer load = (Customer) session.load(Customer.class, 19);
System.out.println("----------------sql语句发送");
System.out.println(load.getName());
//--------------------------------------
session.getTransaction().commit();
session.close();
}

hibernate (一对多)加载策略

关联级别懒加载的配置以及查询方式:

lazy:false

  //关联级别懒加载
//lazy:false
public void fun2() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
Customer load = (Customer) session.get(Customer.class, 19); System.out.println("所有的--------sql语句发送");
for (Order o : load.getOrders()) {
System.out.println(o.getName());
}
//--------------------------------------
session.getTransaction().commit();
session.close();
}


fetch:

fetch:join  / lazy:false  立刻使用select语句加载集合数据
fetch:join  / lazy:true  立刻使用select语句加载集合数据
fetch:join  / lazy:extra  立刻使用select语句加载集合数据

两种相同:会立刻加载出集合数据

fetch:join  / lazy:ture  查询集合时使用表连接查询,会立刻加载出集合数据 //关联级别懒加载
//lazy:false
//fetch :join
public void fun3() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
Customer load = (Customer) session.get(Customer.class, 19); System.out.println("左外连接查询--------sql语句发送");
for (Order o : load.getOrders()) {
System.out.println(o.getName());
}
//--------------------------------------
session.getTransaction().commit();
session.close();
}

select:(默认)表连接语句查询集合数据  lazy:false

fetch:subselect  / lazy:false  立刻使用select语句加载集合数据

一次加载多个customer的订单数据

    //关联级别懒加载
//lazy:false
//fetch :subselect
public void fun4() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
List<Customer> list = session.createQuery("from com.huhu.domain.Customer").list();
for (Customer c : list) {
System.out.println(c.getName() + c.getOrders().size());
}
//--------------------------------------
session.getTransaction().commit();
session.close();
}

fetch:subselect  / lazy:true  立刻使用select语句加载集合数据
    //关联级别懒加载
//lazy:true
//fetch :subselect
public void fun5() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
List<Customer> list = session.createQuery("from com.huhu.domain.Customer").list();
System.out.println("使用order时才去数据库查询");
for (Customer c : list) {
System.out.println(c.getName() + c.getOrders().size());
}
//--------------------------------------
session.getTransaction().commit();
session.close();
}



fetch:select  / lazy:true (默认)普通的查询语句
//关联级别懒加载
//lazy:true
//fetch :select
public void fun6() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
System.out.println("customer--------sql语句发送");
Customer load = (Customer) session.get(Customer.class, 17); System.out.println("order--------sql语句发送");
for (Order o : load.getOrders()) {
System.out.println(o.getName());
}
//--------------------------------------
session.getTransaction().commit();
session.close();
}

fetch:select  / lazy:false  立刻使用select语句加载集合数据
 //关联级别懒加载
//lazy:false
//fetch :select
public void fun7() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
Customer load = (Customer) session.get(Customer.class, 17); System.out.println("所有的--------sql语句发送");
for (Order o : load.getOrders()) {
System.out.println(o.getName());
}
//--------------------------------------
session.getTransaction().commit();
session.close();
}

关联级别懒加载:

由两个属性控制,在关联属性<set>中的两个属性:lazy和fecth,他们的对应值分别为 true,false,extra/select,subselect,join,这样一共有9中方法。仔细看看关于extra。

true/select:(默认值)会在使用集合是加载,普通的select语句

true/subselect:会在使用集合时加载,子查询语句,是延迟加载

true/join和false/join和extra/join:查询时使用表链接查询,会立刻加载集合数据,都没有延时加载

false/select:立刻使用select语句加载集合数据

false/subselect:会在查询customer时,  立即使用子查询加载客户的订单数据

extra:特别懒惰,如果时用集合时,之调用size()方法查询数量时,Hibernate发送count语句,只查询数量,不查询集合内数据
        extra/select
 //关联级别懒加载
//lazy:extra
//fetch :select
public void fun8() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
Customer load = (Customer) session.get(Customer.class, 17); System.out.println("-------查询数量count()------");
System.out.println(load.getOrders().size());
System.out.println("----------查询customer--------");
for (Order o : load.getOrders()) {
System.out.println(o.getName());
}
//--------------------------------------
session.getTransaction().commit();
session.close();
}

extra/subselect

//关联级别懒加载
//lazy:extra
//fetch :subselect
public void fun9() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
List<Customer> list = session.createQuery("from com.huhu.domain.Customer").list();
for (Customer c : list) {
System.out.println(c.getName() + "------------" + c.getOrders().size());
}
for (Customer cs : list) {
for (Order o : cs.getOrders()) {
System.out.println(cs.getName() + "------------" + o.getName());
}
}
//--------------------------------------
session.getTransaction().commit();
session.close();
}

hibernate:加载策略多对一

多对一:
lazy
  false 加载订单时,会立即加载客户
  proxy 看客户对象的类加载策略来决定
  no-proxy : 不做研究. 
  fetch=
select  : (默认值)使用普通select加载

join : 使用表链接加载数据

测试:

package com.huhu.b_lazy;

import com.huhu.domain.Customer;
import com.huhu.domain.Order;
import com.huhu.utils.HibernateUtils;
import org.hibernate.Session; import java.util.List; /**
* 加载策略:多对一
*/
public class HibernateDemo3 { //fetch:select
//lazy:false
//默认:与我关联的数据时,在使用时才会加载。
public void fun1() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
Order order = (Order) session.get(Order.class, 17);
System.out.println(order.getCustomer().getName());
//--------------------------------------
session.getTransaction().commit();
session.close();
} //fetch:select
//lazy:proxy
//Customer类加载策略:lazy :false
//默认:与我关联的数据时,在使用时才会加载。
public void fun2() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
Order order = (Order) session.get(Order.class, 17); //--------------------------------------
session.getTransaction().commit();
session.close();
} //fetch:select
//lazy:proxy
//Customer类加载策略:lazy :true
//默认:与我关联的数据时,在使用时才会加载。
public void fun3() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
Order order = (Order) session.get(Order.class, 19);
System.out.println(order.getCustomer().getName());
//--------------------------------------
session.getTransaction().commit();
session.close();
} //fetch:join
//lazy:proxy|false
//Customer类加载策略:lazy :true
//默认:与我关联的数据时,在使用时才会加载。
public void fun4() {
Session session = HibernateUtils.openSession();
session.beginTransaction();
//--------------------------------------
Order order = (Order) session.get(Order.class, 19);
//--------------------------------------
session.getTransaction().commit();
session.close();
} public static void main(String[] args) {
HibernateDemo3 d = new HibernateDemo3();
d.fun4();
}
}

如果想看代码得话可以复制以上代码测试。

Hibernate -- lazy加载的更多相关文章

  1. hibernate懒加载(转载)

    http://blog.csdn.net/sanjy523892105/article/details/7071139 懒加载详解 懒加载为Hibernate中比较常用的特性之一,下面我们详细来了解下 ...

  2. Hibernate懒加载的三种解决方案

    Hibernate懒加载的两种解决方案: 1.Hibernate.initialize(代理对象) 2.在*.hbm.xml映射文件中添加lazy="false"属性 3.使用op ...

  3. Hibernate懒加载解析

    Hibernate懒加载解析 在Hibernate框架中,当我们要访问的数据量过大时,明显用缓存不太合适, 因为内存容量有限 ,为了减少并发量,减少系统资源的消耗,这时Hibernate用懒加载机制来 ...

  4. hibernate懒加载

    Hibernate懒加载解析 hibernatejoinsession数据库sqlobject Hibernate懒加载解析 在Hibernate框架中,当我们要访问的数据量过大时,明显用缓存不太合适 ...

  5. 【转】hibernate懒加载的问题,failed to lazily initialize a collection of role

    hibernate懒加载的问题,failed to lazily initialize a collection of role hibernate懒加载的问题,failed to lazily in ...

  6. Hibernate懒加载深入分析

    Hibernate懒加载深入分析 懒加载可以提高性能吗?  不可以简单的说"能",因为Hibernate的关系映射拖累了SQL的性能,所以想出懒加载来弥补.只是弥补而以,不会超越. ...

  7. -java转json hibernate懒加载造成的无限递归问题

    1.在判断到底是谁维护关联关系时,可以通过查看外键,哪个实体类定义了外键,哪个类就负责维护关联关系. JoinColumn(name="pid") 2. 在保存数据时,总是先保存的 ...

  8. Hibernate懒加载导致json数据对象传输异常的问题---(非常重要)

    1. 异常: [console_demo][WARN] [2016-12-15 19:49:35] org.springframework.web.servlet.mvc.support.Defaul ...

  9. 关于s2sh框架关于hibernate懒加载问题的说明和解决方案

    首先我们来看下面这个图,解释了一个web程序的一次请求流程! 懒加载异常的说明: 懒加载就是我们在查询一个对象时,它所有的属性是否要被查出来! 如果懒加载开启的话,session在service层就被 ...

随机推荐

  1. 5、web站点架构模式简介及Nginx

    LB Cluster: 提升系统容量的方式: scale up:向上扩展 scale out:向外扩展 LVS工作在内核中,本身的数量不受套接字数量限制,利用LVS做调度器,优化得当的话,并发数量可以 ...

  2. C语言学习之桶排序

    之前的博文写了交换(冒泡)排序.选择排序,本文就写写桶排序.不过我理解的这样不算是真正上的桶排序,我的比较简单而真正的桶排序是比较复杂的,暂且就叫桶排序吧. 桶排序在排序中应该用的不多吧,个人理解的是 ...

  3. npm介绍和使用

    # npm 介绍 > 概念 : node 包管理工具 > 作用 : 通过 npm 来快速下载/安装项目中依赖的包 > 查看 版本号 : npm -v     # npm 基本使用演示 ...

  4. http协议的状态码解释

    一些常见的状态码为: 200 – 服务器成功返回网页 404 – 请求的网页不存在 503 – 服务器超时 下面提供 HTTP 状态码的完整列表.点击链接可了解详情.您也可以访问 HTTP 状态码上的 ...

  5. _itemmod_enchant_groups

    随机附魔组 附魔组 `groupId` 分组编号,同一groupId的附魔效果被随机抽取 `enchantId` 附魔Id 对应SpellItemEnchantment.dbc `chance` 被抽 ...

  6. _itemmod_extra_equipments

    双甲 可以控制获得属性的倍率,及是否可以取回物 `stat_muil`属性倍率(item_template中stat) `enchant_muil`附魔效果中的属性倍率(一些附魔会提升属性,可在些配置 ...

  7. 【BZOJ】4013: [HNOI2015]实验比较

    题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=4013 中第i 条涉及的图片对为(KXi, Xi),判断要么是KXi < Xi ,要么 ...

  8. Your CPU supports instructions that this TensorFlow binary was not compiled to use: AVX2 FMA

    解决方法: 如果安装的是GPU版本 如果你有一个GPU,你不应该关心AVX的支持,因为大多数昂贵的操作将被分派到一个GPU设备上(除非明确地设置).在这种情况下,您可以简单地忽略此警告: import ...

  9. 数据库锁机制(以MySQL为例)

    选自:https://blog.csdn.net/aluomaidi/article/details/52460844 https://www.zhihu.com/question/51513268/ ...

  10. vuex深入理解 modules

    一.什么是module? 背景:在Vue中State使用是单一状态树结构,应该的所有的状态都放在state里面,如果项目比较复杂,那state是一个很大的对象,store对象也将对变得非常大,难于管理 ...