博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Hibernate性能优化
阅读量:4048 次
发布时间:2019-05-25

本文共 2463 字,大约阅读时间需要 8 分钟。

性能优化是一个很大的话题,大到程序架构优化,数据库设计等,小到一个特定算法,甚至js优化等等。这里我们只简单谈一下hibernate的性能优化。

在使用Hibernate的时候,通过正确的方法和策略,可以提高执行效率。

 

(一)抓取策略

抓取策略(fetching strategy)是指:当应用程序需要在(Hibernate实体对象图的)关联关系间进行导航的时候, Hibernate如何获取关联对象的策略。抓取策略可以在O/R映射的元数据中声明,也可以在特定的HQL 或条件查询(Criteria Query)中重载声明。

 

例如单端代理,集合代理,批量抓取等

 

设置方式通常为

*fetch="join",hibernate会通过一个select语句连接(内联/外联)抓取其关联对象或集合

*fetch="subselect",另外发送一条select语句抓取在前面查询到的所有实体的关联集合

*可以使用fetch预抓取Classes,解决N+1问题,hql中使用“join fetch ” ,select s from Student s join fetch s.classes  where s.id in(:ids)

*batch-size属性,可以批量加载实体类

 

(二)缓存

缓存原则:通常读远远大于写的数据进行缓存

 

Hibernate的Session在事务级别进行持久化数据的缓存操作。 当然,也有可能分别为每个类(或集合),配置集群、或JVM级别(SessionFactory级别)的缓存。 你甚至可以为之插入一个集群的缓存。注意,缓存永远不知道其他应用程序对持久化仓库(数据库)可能进行的修改 (即使可以将缓存数据设定为定期失效)。

 

1、一级缓存

 

一级缓存生命周期很短和session的生命周期一致,一级缓存也叫session级的缓存或事务级缓存

 

* load/get/iterate查询实体对象时,支持一级缓存

 

* 一级缓存是缓存实体对像的,对属性不缓存

 

*对于 大批量的数据添加

 

session.beginTransaction();

for (int i=0; i<100000; i++) {

Student student = new Student();

student.setName("张三" + i);

session.save(student);

//每20条更新一次

if (i % 20 == 0) {

session.flush();

//清除缓存的内容

session.clear();

}

}

session.getTransaction().commit();

 

 

2、二级缓存

 

二级缓存也称为进程级的缓存或SessionFactory级的缓存,二级缓存可以被所有的session共享

 

二级缓存的生命周期和SessionFactory的生命周期一致,SessionFactory可以管理二级缓存

 

二级缓存的配置和使用:

* 将ehcache.xml文件拷贝到src下

* 在hibernate.cfg.xml文件中加入缓存产品提供商

<property name="hibernate.cache.provider_class">org.hibernate.cache.EhCacheProvider</property>

* 启用二级缓存,这也是它的默认配置

<property name="hibernate.cache.use_second_level_cache">true</property>

* 指定哪些实体类使用二级缓存

可以在映射文件中采用<cache>标签指定或在hibernate.cfg.xml文件中统一指定

如:

<!--

指定Student使用二级缓存

 -->

<class-cache class="com.bjpowernode.hibernate.Student" usage="read-only"/>

注意使用缓存的策略,通常采用read-only和read-write

 

 *二级缓存主要是缓存实体对象      

*如果要清除二级缓存中的某些对象

//HibernateUtils.getSessionFactory().evict(Student.class);

HibernateUtils.getSessionFactory().evict(Student.class, 1);

 

*注意大批量数据更新时,如果配置了二级缓存建议禁用一级缓存和二级缓存的交互

session.beginTransaction();

 

//禁止一级缓存和二级缓存交互

session.setCacheMode(CacheMode.IGNORE);

for (int i=0; i<100; i++) {

Student student = new Student();

student.setName("张三" + i);

session.save(student);

//每20条更新一次

if (i % 20 == 0) {

session.flush();

//清除缓存的内容

session.clear();

}

}

session.getTransaction().commit();

 

(三)查询缓存

* 查询缓存是缓存普通属性结果集的

* 对实体对象的结果集会缓存id(在查询缓存中,它并不缓存结果集中所包含的实体的确切状态;它只缓存这些实体的标识符属性的值、以及各值类型的结果。  )

 

查询缓存的生命周期,当关联的表发生修改,查询缓存的生命周期结束

 

查询缓存的配置和使用:

* 修改hibernate.cfg.xml文件,来开启查询缓存,默认是false是不起用的

<property name="hibernate.cache.use_query_cache">true</property>        

* 必须在程序启用

query.setCacheable(true)

转载地址:http://drdci.baihongyu.com/

你可能感兴趣的文章
linux CPU个数查看
查看>>
分布式应用开发相关的面试题收集
查看>>
简单理解Socket及TCP/IP、Http、Socket的区别
查看>>
利用HTTP Cache来优化网站
查看>>
利用负载均衡优化和加速HTTP应用
查看>>
消息队列设计精要
查看>>
分布式缓存负载均衡负载均衡的缓存处理:虚拟节点对一致性hash的改进
查看>>
分布式存储系统设计(1)—— 系统架构
查看>>
MySQL数据库的高可用方案总结
查看>>
常用排序算法总结(一) 比较算法总结
查看>>
SSH原理与运用
查看>>
SIGN UP BEC2
查看>>
S3C2440中对LED驱动电路的理解
查看>>
《天亮了》韩红
查看>>
Windows CE下USB摄像头驱动开发(以OV511为例,附带全部源代码以及讲解) [转]
查看>>
模拟屏学习资料_什么是PAL制式
查看>>
模拟屏学习资料_模拟视频 入门
查看>>
西藏之旅
查看>>
Oracle中定时执行问题
查看>>
三时业
查看>>