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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 数据库四大特性_Mysql数据库四种特性

    数据库四大特性_Mysql数据库四种特性1、原子性(Atomicity):原子性是指事务是一个不可分割的工作单位,事务中的操作要么全部成功,要么全部失败。比如在同一个事务中的SQL语句,要么全部执行成功,要么全部执行失败。2、一致性(Co

    2022年8月4日
    8
  • linux centos7配置网络教程,linux centos7配置网络「建议收藏」

    linux centos7配置网络教程,linux centos7配置网络「建议收藏」1.动态获取ip(前提是你的路由器已经开启了DHCP)修改网卡配置文件vi/etc/sysconfig/network-scripts/ifcfg-ens32(最后一个为网卡名称)动态获取IP地址需要修改两处地方即可(1)bootproto=dhcp(2)onboot=yes修改后重启一下网络服务即可systemctlrestartnetwork2、配置静态IP地址设置静态IP地…

    2022年5月8日
    46
  • 计算机组成原理 时钟周期_什么是指令周期机器周期和时钟周期

    计算机组成原理 时钟周期_什么是指令周期机器周期和时钟周期时钟周期:一个时钟脉冲所需要的时间。在计算机组成原理中又叫T周期或节拍脉冲。是CPU和其他单片机的基本时间单位。它可以表示为时钟晶振频率(1秒钟的时钟脉冲数)的倒数(也就是1s/时钟脉冲数,比如1/12MHz),对CPU来说,在一个时钟周期内,CPU仅完成一个最基本的动作。时钟脉冲是计算机的基本工作脉冲,控制着计算机的工作节奏。时钟频率越高,时钟周期就越短,工作速度也就越快。时钟周期在CPU的描述…

    2022年10月13日
    3
  • win10专业版虚拟机配置服务器,win10专业版怎么运行虚拟机_win10专业版开启虚拟机的方法…

    win10专业版虚拟机配置服务器,win10专业版怎么运行虚拟机_win10专业版开启虚拟机的方法…虚拟机大家应该都很熟悉吧 就是允许你在当前操作系统中运行其他操作系统 虚拟操作系统会像你电脑上的另一个程序一样运行 有 win10 专业版系统用户想要运行虚拟机 可是却不知要怎么操作 其实系统中自带有虚拟机功能 我们只要将其开启就可以了 接下来给大家分享一下 win10 专业版开启虚拟机的方法 具体步骤如下 1 首先要找到控制面板 我们点开 windows 键 然后选择在所有应用中找到 Windows 系统

    2025年8月1日
    6
  • 怪诞行为学丹 . 艾瑞里_怪诞心理学epub

    怪诞行为学丹 . 艾瑞里_怪诞心理学epub郑重声明:本号收录的电子书均来源于互联网或网友分享,链接内容仅作分享交流学习使用,不用于任何商业用途,版权归原作者和出版社所有,如果喜欢,请支持和购买正版,谢谢。下载地址:http://pan.63

    2022年8月3日
    5
  • Liquibase的简单使用[通俗易懂]

    Liquibase的简单使用[通俗易懂]`LiquiBase`是一个用于数据库重构和迁移的开源工具,通过日志文件的形式记录数据库的变更,然后执行日志文件中的修改,将数据库更新或回滚到一致的状态。它的目标是提供一种数据库类型无关的解决方案,通

    2022年8月5日
    6

发表回复

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

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