Hibernate-缓存/懒加载/抓取策略
懒加载测试:
/*类的延迟加载
*
* session.get
* 1、方法加载出来的对象是class对象
* 2、在session.get方法执行的时候发出sql语句
* 3、class对象是有值的
* session.load
* 1、方法加载出来的对象是class的代理对象
* 2、在加载其属性的时候发出sql语句(按照需求加载,延迟加载)
* 3、获取标识符属性是不用延迟加载的,获取普通属性是需要发出sql语句的
* 标识符属性对于延迟加载不起作用
*/
映射文件: Class.hbm.xml
实体类: Class
Hibernate类的延迟加载测试:
Configuration configuration = new Configuration();
configuration.configure("com/hibernate/lazy/hibernate.cfg.xml");
sessionFactory = configuration.buildSessionFactory();
ClassLazyTest:
session.get(CLass.class,1L); session.close();
session.load(CLass.class,1L); session.close(); /*
* session.get
* 1、方法加载出来的对象是class对象
* 2、在session.get方法执行的时候发出sql语句
* 3、class对象是有值的
session.load
* 1、方法加载出来的对象是class的代理对象
* 2、在加载其属性的时候发出sql语句(按照需求加载,延迟加载)
* 3、获取标识符属性是不用延迟加载的,获取普通属性是需要发出sql语句的标识符属性对于延迟加载不起作用
*/ ReferenceRelationTest:
Class user =(Class)session.get(Class.class,1L);
Set<Student> student = user.getStudents();
for(Student stu : student)
{
System.out.println(stu.getName());
}
seesion.close(); 深入:
/*
* 当集合的lazy为true时
* Hibernate: select students0_.cid as cid0_1_, students0_.sid as sid1_, students0_.sid as sid1_0_, students0_.sname as sname1_0_, students0_.cid as cid1_0_ from student students0_ where students0_.cid=?
* 当集合的lazy为extra时 extra为更进一步的延迟加载
* Hibernate: select count(sid) from student where cid =?
*/
那什么时候使用懒加载? 处理大数据量时,为了减少对数据库的查询次数和对数据的取舍(有些没用到的关联数据夜查出来了),这时候就应当使用它。
抓取策略:
部分代码测试贴上:
/*
* 抓取策略
* 例子:在加载class的时候怎么样去加载student
* 应用范围:在加载一端对象的时候,去加载多的一端对象的时候的方式
* 抓取策略和延迟加载----->研究对象是集合,这一点应该不难理解,懒加载是在一对多/多对多关联中,从的一方拿数据是否延迟加载多的那方。 抓取策略则是操作者本身已经明确了需要获取哪些数据,并且是在关联关系简单生成的SQL语句却很多,针对的也是一对多/多对多的关系
* lazy fetch
* false select 有作用
* true join 延迟加载失效
* false subselect 有作用
*
* 总结:当fetch为join时,延迟加载失去作用
* 当fetch为select时或者为subselect时,延迟加载能控制sql语句的发出时间
*
*/
public class FetchTest {
private static SessionFactory sessionFactory = null;
static {
Configuration configuration = new Configuration();
configuration.configure("cn/heima5/hibernate/fetch/hibernate.cfg.xml");
sessionFactory = configuration.buildSessionFactory();
} /*
* 先查询所有的class数据,再根据class查询student,其本身的查询符合子查询
* 所以在这个例子中,可以用fetch="subselect"提高效率 1、如果用fetch="select"将导致n+1次查询
* n代表class表中的行数 2、用fetch="join"不起作用
* 3、应用fetch="subselect"或者fetch="select"与batch-size结合起来使用
*/
@Test
public void testQuery() {
Session session = sessionFactory.openSession(); List<Class> classList = session.createQuery("from Class").list(); for (Class class1 : classList) {
Set<Student> students = class1.getStudents();
for (Student student : students) {
System.out.println(student.getSname());
}
} session.close();
}
/*
* 说明
* 1、如果fetch="select"发出两条sql语句
* 第一条查询给定的ID的值的class对象
* 第二条查询根据cid查询student
* 2、如果fetch="join",发出一条sql语句 左外连接
*/
@Test
public void testQuery2() {
Session session = sessionFactory.openSession(); Class class1 = (Class)session.get(Class.class, 1L); Set<Student> students = class1.getStudents();
for (Student student : students) {
System.out.println(student.getSname());
} session.close();
}
/*
* 通过分析属于子查询的内容,所以抓取策略为fecth="subselect"
*/
@Test
public void testQuery3(){
Session session = sessionFactory.openSession(); List<Class> classList = session.createQuery("from Class where cid in(1,2,3,5,7)").list(); for (Class class1 : classList) {
Set<Student> students = class1.getStudents();
for (Student student : students) {
System.out.println(student.getSname());
}
} session.close();
}
总结:当fetch为join时,延迟加载失去作用
当fetch为select时或者为subselect时,延迟加载能控制sql语句的发出时间
Session缓存:
后续更新
Hibernate-缓存/懒加载/抓取策略的更多相关文章
- hibernate detached分离查询 与 抓取策略注意事项
1.detached在抓取策略为 jion显式左外连接查询情况下 会产生笛卡儿积现象 DetachedCriteria dc = DetachedCriteria.forClass(Topic.cla ...
- hibernate的懒加载问题
产生原因: 当使用hibernate查询一个对象的时候,如果Session关闭,再调用该对象关联的集合或者对象的时候,会产生懒加载异常! 解决方案: 方案一: 在Session关闭之前,查询对象关联的 ...
- Hibernate的懒加载session丢失解决方法
在web.xml加入spring提供的过滤器,延长session的生命周期 <!--Hibernate的懒加载session丢失解决方法 --> <filter> <fi ...
- Hibernate学习笔记(八) — 懒载入与抓取策略
懒载入(Load On Demand)是一种独特而又强大的数据获取方法,它可以在用户滚动页面的时候自己主动获取很多其它的数据,而新得到的数据不会影响原有数据的显示,同一时候最大程度上降低server端 ...
- hibernate的懒加载
WHY? WHAT? HOW? 所谓懒加载(lazy)就是延时加载,延迟加载.即不是不加载,而是在需要的时候才加载. 什么时候用懒加载呢,我只能回答要用懒加载的时候就用懒加载. 至于为什么要用懒加载呢 ...
- 【转】Hibernate 原汁原味的四种抓取策略
最近在研究 Hibernate 的性能优化的时候碰到了"抓取策略", 由于以前没有详细的研究过, 所以到处找资料, 但是无论从一些讲 Hibernate 书籍,还是他人 Blog ...
- Hibernate 原汁原味的四种抓取策略(转)
原文出处:http://www.cnblogs.com/rongxh7/archive/2010/05/12/1733088.html 尊重原作者,访问原创地址 最近在研究 Hibernate ...
- hibernate+spring mvc, 解决hibernate 对象懒加载 json序列化问题
引用地址 在使用Spring MVC时,@ResponseBody 注解的方法返回一个有懒加载对象的时候出现了异常,以登录为例: @RequestMapping("login") ...
- hibernate+spring mvc,解决hibernate对象懒加载,json序列化失败
在使用spring MVC时,@ResponseBody 注解的方法返回一个有懒加载对象的时候出现了异常,以登录为例: @RequestMapping("login") @Resp ...
随机推荐
- artDialog弹出框使用
配置参数 名称 类型 默认值 描述 内容 title String '消息' 标题内容 content String 'loading..' 消息内容.1.如果传入的是HTMLElement类型,如果 ...
- webpack配置:打包第三方类库、第三方类库抽离、watch自动打包、集中拷贝静态资源
一.打包第三方类库 下面说2种方法: 第一种: 1.引入jQuery,首先安装: npm install --save-dev jquery 2.安装好后,在index.js中引入,用jquery语法 ...
- kafka启动报错:kafka.common.KafkaException: Failed to acquire lock on file .lock
kafka 异常退出后重启时遇到的问题 解决: 执行 netstat -lnp|grep 9092 在执行结果中找到进程号执行 kill -9 进程号再尝试启动Kafka
- [Microsoft][SQLServer 2000 Driver for JDBC]Error establishing socket错误解决方法总结
今天做一个特殊的业务处理,用JDBC连接SQLServer数据库载入驱动的时候,报例如以下错误: java.sql.SQLException: [Microsoft][SQLServer 2000 D ...
- EazyUI主页框架搭建纯JS样例
採用Jfinal+EazyUI 执行起来就好能够了 眼下还未增加后台代码 纯JS代码搭建的一个二级菜单+主页 客户换肤, 给使用EazyUI的新人一个高速可用的JS 搭建界面 也给自己保存下 界面 ...
- $ gulp watch 运行出错解决方法
$ gulp watch 运行出错解决方法 $ gulp watch 如果你出现了如下报错信息: gulp-notify: [Laravel Elixir] Browserify Fail ...
- Cocos2dx 3.6源代码编译错误:syntax error : missing ')' before '{'
在编译Cocos2dx 3.6版本号时.发现编译错误: 定位代码行: debugForNormalSprite->drawPoints(positions, 4, 8, Color4F{0.0, ...
- hdu 3641 数论 二分求符合条件的最小值数学杂题
http://acm.hdu.edu.cn/showproblem.php?pid=3641 学到: 1.二分求符合条件的最小值 /*================================= ...
- 【Java】取当前.class文件的编译位置
本文与<[C++]求当前exe的执行路径>(点击打开链接)为姊妹篇.C++在win下生成的执行文件是.exe.Java生成的执行文件是.class然后自己主动扔到Java虚拟机中执行.主要 ...
- awk按列求和
awk 'BEGIN{total=0}{total+=$1}END{print total}'