hibernate二级缓存配置[通俗易懂]

hibernate二级缓存配置[通俗易懂] 二级缓存配置:    1、首先要打开二级缓存,在hibernate.cfg.xml中添加如下配置:  property name=”hibernate.cache.use_second_level_cache”>trueproperty>    2、Hibernate的二级缓存使用第三方的缓存工具来实现,所以我们需要指定Hibernate使用哪个     缓存工

大家好,又见面了,我是你们的朋友全栈君。 

  1. 二级缓存配置:   
  2.   
  3. 1、首先要打开二级缓存,在hibernate.cfg.xml中添加如下配置:   
  4. <property name=“hibernate.cache.use_second_level_cache”>true</property>  
  5.   
  6. 2、Hibernate的二级缓存使用第三方的缓存工具来实现,所以我们需要指定Hibernate使用哪个   
  7.    缓存工具。如下配置指定Hibernate使用EhCache缓存工具。   
  8. <property name=“hibernate.cache.provider_class”>org.hibernate.cache.EhCacheProvider</property>  
  9.   
  10. 3、Hibernate在默认情况下并不会对所有实体对象进行缓存,所以,我们需要指定缓存哪些对象,   
  11. 在实体对象的映射文件中(相应的<class>标签内部),添加如下配置:   
  12. <cache usage=“read-only”/>  
  13.   
  14. usage=“read-only”是“只读”缓存策略。   
  15.   
  16. 注意,这个<cache>标签只能放在<class>标签的内部,而且必须处在<id>标签的前面!!!   
  17. 这个<cache>标签放在哪些<class>标签下面,就说明会多这些类的对象进行缓存   
  18.   
  19. 4、对于第3步,有一个可选的方案是在hibernate.cfg.xml文件中指定哪些类的对象需要缓存,   
  20.    而不需要使用<cache>标签来指定。如:   
  21.    在hibernate.cfg.xml中添加如下配置:   
  22.    <class-cache class=“com.bjsxt.hibernate.Classes” usage=“read-only” />  
  23.      
  24.    注意,这个<class-cache>标签必须放在<mapping>标签的后面!!  

1、首先设置EhCache,建立配置文件ehcache.xml,默认的位置在class-path,可以放到你的src目录下:

<?xml version=”1.0″ encoding=”UTF-8″?>
<ehcache>
 <diskStore path=”java.io.tmpdir”/>
  <defaultCache
   maxElementsInMemory=”10000″ <!– 缓存最大数目 –>
   eternal=”false” <!– 缓存是否持久 –>
   overflowToDisk=”true” <!– 是否保存到磁盘,当系统当机时–>
   timeToIdleSeconds=”300″ <!– 当缓存闲置n秒后销毁 –>
   timeToLiveSeconds=”180″ <!– 当缓存存活n秒后销毁–>
   diskPersistent=”false”
   diskExpiryThreadIntervalSeconds= “120”/>
</ehcache>

  2、在Hibernate配置文件中设置:

<!– 设置Hibernate的缓存接口类,这个类在Hibernate包中 –>
<property name=”cache.provider_class”>org.hibernate.cache.EhCacheProvider</property>
 <!– 是否使用查询缓存 –>
 <property name=”hibernate.cache.use_query_cache”>true</property>
  如果使用spring调用Hibernate的sessionFactory的话,这样设置:
  <!–HibernateSession工厂管理 –>
   <bean id=”sessionFactory” class=”org.springframework.orm.hibernate3.LocalSessionFactoryBean”>
   <property name=”dataSource”>
    <ref bean=”datasource” />
   </property>
   <property name=”hibernateProperties”>
   <props>
    <prop key=”hibernate.dialect”>org.hibernate.dialect.Oracle9Dialect</prop>
    <prop key=”connection.provider_class”>org.hibernate.connection.C3P0ConnectionProvider</prop>
    <prop key=”hibernate.show_sql”>true</prop>
    <prop key=”hibernate.cache.use_query_cache”>true</prop>
    <prop key=”hibernate.cache.provider_class”>org.hibernate.cache.EhCacheProvider</prop>
   </props>
 </property>
 <property name=”mappingDirectoryLocations”>
  <list>
   <value>/WEB-INF/classes/cn/rmic/manager/hibernate/</value>
  </list>
 </property>
</bean>

  说明一下:如果不设置“查询缓存”,那么hibernate只会缓存使用load()方法获得的单个持久化对象,如果想缓存使用 findall()、list()、Iterator()、createCriteria()、createQuery()等方法获得的数据结果集的话, 就需要设置
hibernate.cache.use_query_cache true 才行

  3、在Hbm文件中添加<cache usage=”read-only”/>

  4、如果需要“查询缓存”,还需要在使用Query或Criteria()时设置其setCacheable(true);属性

  5、实践出真知,给一段测试程序,如果成功的话第二次查询时不会读取数据库

package cn.rmic.hibernatesample;

import java.util.List;

import org.hibernate.CacheMode;
import org.hibernate.Criteria;
import org.hibernate.Query;
import org.hibernate.Session;

import cn.rmic.hibernatesample.hibernate.HibernateSessionFactory;
import cn.rmic.manager.po.Resources;

public class testCacheSelectList …{

 /** *//**
 * @param args
 */
 public static void main(String[] args) …{
  // TODO Auto-generated method stub

  Session s=HibernateSessionFactory.getSession();
  Criteria c=s.createCriteria(Resources.class);
  c.setCacheable(true);
  List l=c.list();
  // Query q=s.createQuery(“From Resources r”)
  // .setCacheable(true)
  // .setCacheRegion(“frontpages”) ;
  // List l=q.list();
  Resources resources=(Resources)l.get(0);
  System.out.println(“-1-“+resources.getName());
  HibernateSessionFactory.closeSession();
  try …{
   Thread.sleep(5000);
  } catch (InterruptedException e) …{
   // TODO Auto-generated catch block
   e.printStackTrace();
  }
  s=HibernateSessionFactory.getSession();
  c=s.createCriteria(Resources.class);
  c.setCacheable(true);
  l=c.list();
  // q=s.createQuery(“From Resources r”).setCacheable(true)
  // .setCacheRegion(“frontpages”);
  // l=q.list();
  resources=(Resources)l.get(0);
  System.out.println(“-2-“+resources.getName());
  HibernateSessionFactory.closeSession();
 }
}

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/142250.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 牛客网–字符串排序

    牛客网–字符串排序

    2021年5月19日
    91
  • spring data jpa 深入浅出的理解「建议收藏」

    spring data jpa 深入浅出的理解「建议收藏」文章来源于:https://www.cnblogs.com/cmfwm/p/8109433.html这是一篇写得很不错的关于spring-data-jpa的文章,转载到此,方便大家学习交流.本篇进行Spring-data-jpa的介绍,几乎涵盖该框架的所有方面,在日常的开发当中,基本上能满足所有需求。这里不讲解JPA和Spring-data-jpa单独使用,所有的内容都是在和Spri…

    2022年5月5日
    40
  • tkmapper教程_tkr和tka的区别

    tkmapper教程_tkr和tka的区别tkMapper入门1、tkMapper介绍1.1SpringBoot整合MyBatis以及tkMapper1.2在启动类上修改注解`@MapperScan`2、tkMapper的使用2.1创建数据表2.2创建实体类2.3创建Mapper接口2.4测试3、tkMapper的常用方法3.1类别实体类3.2类别接口增加修改删除查询查询所有根据主键查询条件查询分页查询带条件的分页查询关联查询1、通过多个单表操作实现2、自定义连接查询2.1、在DAO接口自定义方法2.2、创建Mapper文件1、

    2022年10月7日
    4
  • js正则截取指定字符串_java正则表达式提取字符串

    js正则截取指定字符串_java正则表达式提取字符串一、javascript正则表达式的基本知识1javascript正则对象创建和用法声明javascript正则表达式varreCat=newRegExp(“cat”);你也可以varreCat=/cat/;//Perl风格(推荐)2学习最常用的testexecmatchsearchreplacesplit6个方法1)test检查指定的字符串是否存在vardata=“123123″;varreCat=/123/gi;alert(r

    2022年9月20日
    2
  • arm 体系架构及其工作原理图_arm架构详解

    arm 体系架构及其工作原理图_arm架构详解架构的演变历史我们首先介绍ARMLtd,这里先说的是公司而不是架构。ARM的发展历史非常久远,超乎许多人的想象。首先,我们提供一些背景信息,ARM成立于20世纪90年代末,从另一家位于剑桥的公司分拆而来,那家公司叫做AcornComputers,曾经是英国教育市场的著名个人台式计算机供应商,现已不复存在。80年代中期时,Acorn一个小团队接受了一个挑战,为他们的下一代计…

    2022年10月14日
    6
  • 艾伟:memcached全面剖析–2.理解memcached的内存存储

    艾伟:memcached全面剖析–2.理解memcached的内存存储

    2021年8月13日
    47

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号