一级缓存(session级别的缓存)
List<User> users=(List<User>)session.createQuery(SQL);
Iterator<User> users=(Iterator<User>)session.createQuery(SQL);
List------->直接数据库加载User
Iterator----->读出来的是ID------->先在session中找----.>在二级缓存中找(如果提供二级缓存)------->再在数据库中加载
二级缓存(sessionFactory级别)
它需要第三方的 缓存提供商。
如EHCache,jboss。适合1常用2不常变更3数量有限
步骤:
1,在hibernate.cfg.xml中打开二级缓存,指明缓存提供商
<property name="cache.use_second_level_cache">true</property>
<property name="cache.provider_class">
org.hibernate.cache.EhCacheProvider
</property>
2,引入EHCache的jar包,hibernate/lib/optional/ehcache目录下
和ehcache.xml二级缓存的配置文件
3,hibernate的注解,指明那些实体查询后放入二级缓存中。
@Cache(usage=) usage指明了实体的是只读还是读写等等特性
class User{}
查询缓存(依赖二级缓存)
步骤:1,在hibernate.cfg.xml中打开查询缓存
<property name="cache.use_query_cache">true</property>
2,在代码中指明要使用查询缓存
query.setCachable(true) :Query
分享到:
相关推荐
Hibernate性能优化Hibernate性能优化Hibernate性能优化Hibernate性能优化Hibernate性能优化
珍藏的hibernate性能优化,如果对hibernate进行优化,很详细,是工作和面试的好助手
Hibernate性能优化研究.pdf..............
Hibernate性能优化策略.详细描述了java性能优化的各种策略高清
hibernate性能优化.dochibernate性能优化.doc
设计好的hibernate与设计不好的hibernate性能差别巨大,如何改善hibernate的性能是合理使用hibernate的关键
Hibernate性能优化共9页.pdf.zip
hibernate性能优化[参考].pdf
NULL 博文链接:https://quicker.iteye.com/blog/660498
首先是找到了hibernate的启动优化 http://www.hibernate.org/194.html 里面的主要思想是通过将xml序列花到本地的文件里,每次读取的时候根据情况,从本地文件读取并反序列化,节省了hibernate xml的解析时间。
初用HIBERNATE的人也许都遇到过性能问题,实现同一功能,用HIBERNATE与用JDBC性能相差十几倍很正常,如果不及早调整,很可能影响整个项目的进度。
NULL 博文链接:https://quicker.iteye.com/blog/660523
hibernate_性能优化
Hibernate3性能优化Hibernate3性能优化Hibernate3性能优化Hibernate3性能优化