1、 检索方式

1  立即检索:立即查询,在执行查询语句时,立即查询所有的数据。

2 延迟检索:延迟查询,在执行查询语句之后,在需要时在查询。(懒加载)

2、  检查策略

1  类级别检索:当前的类的属性获取是否需要延迟。

2  关联级别的检索:当前类 关联 另一个类是否需要延迟。

3、类级别检索

1  get:立即检索。get方法一执行,立即查询所有字段的数据。

2 load:延迟检索。默认情况,load方法执行后,如果只使用OID的值不进行查询,如果要使用其他属性值将查询 。 Customer.hbm.xml  <class  lazy="true | false">

lazy 默认值true,表示延迟检索,如果设置false表示立即检索,相当于get方法。

package com.alice.hibernate02.lazy;

import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test; import com.alice.hibernate02.util.HibernateUtil;
import com.alice.hibernate02.vo.Customer; public class Demo1 {
// 类级别懒加载
// load方法
// class lazy属性
// 默认值: true load获得时,会返回代理对象,不查询数据库.使用时才查询
@Test
public void test01(){
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = (Customer) session.load(Customer.class, 6); System.out.println(cus.getName()); tran.commit();
session.close();
}
//类级别懒加载
//load方法
// class lazy属性
// lazy: false load方法执行就会发送sql语句.与get方法一致.
@Test
public void test02(){
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = (Customer) session.load(Customer.class, 6); System.out.println(cus.getName()); tran.commit();
session.close();
}
}

4、  关联级别检索

在查询有关联关系的数据时,加载一方的数据是否需要将另一方立即查询出.
默认: 与我关联的数据,在使用时才会加载.

集合(一对多):
set
lazy: 是否对set数据使用懒加载
        true:(默认值) 对集合使用才加载
        false: 集合将会被立即加载
        extra: 极其懒惰,如果使用集合时,之调用size方法查询数量, Hibernate会发送count语句,只查询数量.不加载集合内数据.
fetch : 决定加载集合使用的sql语句种类
         select: (默认值) 普通select查询
         join: 表链接语句查询集合数据
         subselect: 使用子查询 一次加载多个Customer的订单数据

fetch lazy 结论
select true 默认值, 会在使用集合时加载,普通select语句
select false 立刻使用select语句加载集合数据
select extra 会在使用集合时加载,普通select语句,如果只是获得集合的长度,会发送Count语句查询长度
join true 查询集合时使用表链接查询,会立刻加载集合数据
join false 查询集合时使用表链接查询,会立刻加载集合数据
jojn extra 查询集合时使用表链接查询,会立刻加载集合数据
subselect true 会在使用集合时加载,子查询语句
subselect false 会在查询用户时,立即使用子查询加载客户的订单数据
subselect extra 会在使用集合时加载,子查询语句,如果只是获得集合的长度,会发送Count语句查询长度.

代码测试:

package com.alice.hibernate02.lazy;

import java.util.List;

import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test; import com.alice.hibernate02.util.HibernateUtil;
import com.alice.hibernate02.vo.Customer;
import com.alice.hibernate02.vo.Order; public class Demo02 {
// 关联级别懒加载
// 默认: 与我关联的数据,在使用时才会加载.
@Test
public void test01() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = (Customer) session.get(Customer.class, 6); for (Order o : cus.getOrders()) {
System.out.println(o.getName());
} tran.commit();
session.close();
}
//关联级别懒加载
//lazy: false
@Test
public void test02() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = (Customer) session.get(Customer.class, 6); for (Order o : cus.getOrders()) {
System.out.println(o.getName());
} tran.commit();
session.close();
} //关联级别懒加载
//lazy:false
//fetch:subselect
@Test
public void test03() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = (Customer) session.get(Customer.class, 6); for (Order o : cus.getOrders()) {
System.out.println(o.getName());
} tran.commit();
session.close();
}
//关联级别懒加载
//lazy:true/false
//fetch:subselect
@Test
public void test04() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); List<Customer> list = session.createQuery("from Customer").list(); for (Customer c: list) {
System.out.println(c.getName()+"下单数量"+c.getOrders().size());
} tran.commit();
session.close();
} //关联级别懒加载
//lazy:extra
//fetch:select
@Test
public void test05() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Customer cus = (Customer) session.get(Customer.class, 6);
//查询Customer下订单 数量
System.out.println(cus.getOrders().size()); //真正使用订单中的数据
for (Order o: cus.getOrders()) {
System.out.println(o.getName());
} tran.commit();
session.close();
}
//关联级别懒加载
//lazy:extra
//fetch:subselect
@Test
public void test06() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); @SuppressWarnings("unchecked")
List<Customer> list = session.createQuery("from Customer").list();
for(Customer c:list){
System.out.println(c.getName()+"下单数量:"+c.getOrders().size());
}
for(Customer c:list){
for(Order o :c.getOrders()){
System.out.println(c.getName()+"下单名称:"+o.getName());
}
}
tran.commit();
session.close();
} }

  多对一:

<many-to-one>

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

join : 使用表链接加载数据

 
fetch lazy 结果
select false 加载订单时,立即加载客户数据.普通select语句加载客户.
select proxy

类加载策略为:lazy=false 同上
lazy=true 加载订单时,先不加载客户数据.使用客户数据时才加载

join false 使用表链接查询订单以及对应客户信息.lazy属性无效
join proxy 使用表链接查询订单以及对应客户信息.lazy属性无效
package com.alice.hibernate02.lazy;

import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test; import com.alice.hibernate02.util.HibernateUtil;
import com.alice.hibernate02.vo.Order; //多对一检索策略
public class Demo03 {
// 多对一检索策略
@Test
// fetch: select
// lazy: false
public void test01() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Order o = (Order) session.get(Order.class, 8);
System.out.println(o.getCustomer().getName()); tran.commit();
session.close();
} // fetch: select
// lazy: proxy
// Customer lazy:false
@Test
public void test02() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Order o = (Order) session.get(Order.class, 8);
System.out.println(o.getCustomer().getName()); tran.commit();
session.close();
} // fetch: select
// lazy: proxy
// Customer lazy:true
@Test
public void test03() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Order o = (Order) session.get(Order.class, 8);
System.out.println(o.getCustomer().getName()); tran.commit();
session.close();
} // fetch: join
// lazy: proxy|false
@Test
public void test04() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); Order o = (Order) session.get(Order.class, 8);
System.out.println(o.getCustomer().getName()); tran.commit();
session.close();
}
}

5、批量加载

set
batch-size: 决定一次加载几个对象的集合数据. in 条件加载多个用户的订单.

package com.alice.hibernate02.lazy;

import java.util.List;

import org.hibernate.Session;
import org.hibernate.Transaction;
import org.junit.Test; import com.alice.hibernate02.util.HibernateUtil;
import com.alice.hibernate02.vo.Customer;
import com.alice.hibernate02.vo.Order;
//批量策略
public class Demo04 { @Test
//查询所有客户
//遍历客户,打印客户下的订单信息
public void test() {
Session session = HibernateUtil.openSession();
Transaction tran = session.beginTransaction(); List<Customer> list = session.createQuery("from Customer").list(); for(Customer c:list){
System.out.println(c.getOrders().size());
} tran.commit();
session.close();
}
}

Customer  Get(int id)

Return Session.load(Customer.class,id);

  1. layz=false
  2. 在Service层获得在页面要上要用到的属性=> 在Service层中确保数据已经

hibernate学习(6)——加载策略(优化)的更多相关文章

  1. hibernate集合的加载策略

    在集合方配置lazy和fetch的方式,默认的是lazy为true,fetch为select,lazy有true,extra和false,true和extra都是懒加载,只是extra比true更懒, ...

  2. Hibernate 加载策略得总结

    Hibernate 加载策略得总结 加载策略(优化查询): 策略种类: 延迟加载: 等到使用的时候才会加载数据. 立即加载: 不管使用不使用,都会立刻将数据加载. 策略的应用: 类级别的加载策略. 关 ...

  3. hibernate框架学习之数据抓取(加载)策略

    Hibernate获取数据方式 lHibernate提供了多种方式获取数据 •load方法获取数据 •get方法获取数据 •Query/ Criteria对象获取数据 lHibernate获取的数据分 ...

  4. hibernate框架学习第六天:QBC、分页查询、投影、数据加载策略、二级缓存

    QBC查询 1.简单查询 Criteria c = s.createCriteria(TeacherModel.class); 2.获取查询结果 多条:list 单挑:uniqueResult 3.分 ...

  5. java之hibernate之加载策略和抓取策略

    1.加载策略:指hibernate查询数据时,采用什么样的方式将数据写入内存.Hibernate中提供了两种方式来加载数据:懒加载和即时加载. 2.懒加载又称延迟加载,指使用hiberante API ...

  6. wemall app商城源码Android之ListView异步加载网络图片(优化缓存机制)

    wemall-mobile是基于WeMall的android app商城,只需要在原商城目录下上传接口文件即可完成服务端的配置,客户端可定制修改.本文分享wemall app商城源码Android之L ...

  7. 【死磕 Spring】----- IOC 之 Spring 统一资源加载策略

    原文出自:http://cmsblogs.com 在学 Java SE 的时候我们学习了一个标准类 java.net.URL,该类在 Java SE 中的定位为统一资源定位器(Uniform Reso ...

  8. hibernate的懒加载

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

  9. ios资源加载策略

    做了好几个月的ios,大框架都是别人搭好的,自己只是实现逻辑,很是失落.慢慢开始整理学习一些概念类的东西吧,希望自己能提高点. cocos2d-x从cocos2d-2.0-x-2.0.2开始,考虑到自 ...

  10. jQuery Pjax – 页面无刷新加载,优化用户体验

    pjax 是 HTML5 pushState 以及 Ajax 两项技术的简称,综合这两个技术可以实现在不刷新页面的情况下载入 HTML 到当前网页,带给你超快速的浏览器体验,而且有固定链接.标题以及后 ...

随机推荐

  1. delphi 各新版本特性收集

    delphi 各新版本特性收集 http://www.cnblogs.com/dreamszx/p/3602589.html

  2. input文本框设置和移除默认值

    input文本框设置和移除默认值 这里想实现的效果是:设置和移除文本框默认值,如下图鼠标放到文本框中的时候,灰字消失. 1.可以用简单的方式,就是给input文本框加上onfocus属性,如下代码: ...

  3. Ubuntu下三个实用的录屏软件

    Ubuntu下三个实用的录屏软件 Kazam 优点: 易安装 可选择区域录制,也可全屏录制 有录屏和截图功能 安装: sudo apt-get install kazam 展示: Simple Scr ...

  4. [转] CC 命令

    1.最基本的操作cleartool co -nc xxx.cppcleartool ci -nc xxx.cpp 2.查看自己总共co了多少文件cleartool lscheckout -cview ...

  5. GitHub使用心得

    PHP今天算是学习结束了;版本控制也了解很久了,比较熟悉的是svn,Git一直都不太熟,也可能是它是英文的缘故,感觉很费劲,所以用的不多,但不得不说,它功能真的很强大;今天试着和朋友用Git开发一个简 ...

  6. 在编译命令行中添加 /D_SCL_SECURE_NO_DEPRECATE

    问题:Add the option /D_SCL_SECURE_NO_DEPRECATE to the compilation command 解决方案:项目属性 –> 配置属性 –> C ...

  7. 对JavaScript中异步同步机制以及线程深入了解

    今天在网上看到各种对Js异步同步单线程多线程的讨论 经过前辈们的洗礼 加上鄙人小小的理解 就来纸上谈兵一下吧~ Js本身就是单线程的 至于为什么Js是单线程的 那就要追溯到Js的历史了 总而言之 由于 ...

  8. NoSQL-Redis【2】-HDEL给我的一个惊喜

    用HDEL删除Hash最后一个域的时候,Redis奇迹般的帮我清除了Key,真是考虑周到啊! 127.0.0.1:6673[2]> HMSET USER:Zhangshan Name 'Zhan ...

  9. apace日常操作和配置

    [root@limt modules]# /usr/sbin/apachectl -h Usage: /usr/sbin/httpd [-D name] [-d directory] [-f file ...

  10. jQuery 使得文本框获得焦点

      今天遇见这么一个小小的问题,就是文本框中需要输入内容才可以提交,如果没有输入就提示并使该文本框获得焦点! 这么一个简单的事情如果没有使用jQuery的话 是不是对象.focus()就可以了, 可是 ...