`
linhui_dragon
  • 浏览: 155223 次
  • 性别: Icon_minigender_2
  • 来自: 北京
社区版块
存档分类
最新评论

hibernate二级缓存

 
阅读更多
Hibernate二级缓存

在一个数据库系统中,如果缓存设置的合适,那么可以极大的提高系统的效率,Hibernate作为一个ORM工具
提供了缓存的机制,包括一级(Session级)缓存和二级(SessionFactory级)缓存。这里主要总结一下二级缓存。

1.首先需要在hibernate.cfg.xml中配置,当然需要导入缓存的jar包

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

    hibernate.cache.use_query_cache必须配置,如果想缓存使用findall()、list()、Iterator()、createCriteria()、
    createQuery()等方法获得的数据结果集。

2.在每个实体的hbm文件中配置cache元素,usage可以是read-only或者是read-write等。
  
<hibernate-mapping>
        <class name="com.xxx.db.base.City" table="city" catalog="haosou">
            <cache usage="nonstrict-read-write"/>
            <id name="citycode" type="string">
                <column name="citycode" />
                <generator class="assigned" />
            </id>
            <property name="city" type="string">
                <column name="city" not-null="true" />
            </property>
            <set name="districts" table="district" cascade="all" inverse="true">
                <key column="citycode" />
                <one-to-many class="com.haosou.db.base.District"/>
            </set>
        </class>
    </hibernate-mapping>
如果相对具体某个类的缓存进行特定的配置,需要在ehcache.xml进行配置:

<cache name="org.qiujy.domain.cachedemo.Category" 
         maxElementsInMemory="100" 
         eternal="true" 
        timeToIdleSeconds="0" 
        timeToLiveSeconds="0" 
         overflowToDisk="false" 
         />          

3.Query或Criteria()时设置其setCacheable(true);

    Session session = HibernateSessionFactory.getCurrentSession();
    Query q = session.createQuery("from City");
    q.setCacheable(true);
    return q.list();
   
    Session session = HibernateSessionFactory.getCurrentSession();
    Query q = session.createQuery("from District d where d.city.citycode='" + cityId + "'");
    q.setCacheable(true);
    return q.list();

    执行以上代码时,第一次会查询数据库,但是后面就直接从缓存中查询,而不会使用数据库的连接,提高了性能。
    以上任一环节都不能少,比如cache元素没有配置,那么就会导致查询district的时候发起N个数据库的连接,这样会极大的降低性能。
分享到:
评论

相关推荐

    Hibernate二级缓存

    Hibernate二级缓存是一种提高应用程序性能的技术,它将数据存储在SessionFactory级别的缓存中,使得数据可以在不同的Session之间共享。这与一级缓存(Session级别)不同,一级缓存仅存在于单个Session生命周期内,当...

    hibernate 二级缓存详解

    Hibernate 二级缓存是针对SessionFactory级别的全局缓存,与一级缓存(Session级别)不同,一级缓存只在单个Session生命周期内有效。二级缓存则允许不同Session之间共享数据,提高了数据访问效率,减少了对数据库的...

    Hibernate 二级缓存

    Hibernate 二级缓存

    hibernate二级缓存实例

    在这个"hibernate二级缓存实例"中,我们将深入探讨二级缓存的原理、配置以及在实际项目中的应用。 首先,我们需要了解一级缓存和二级缓存的区别。一级缓存是Session级别的,每个Session都有自己的一级缓存,用于...

    hibernate二级缓存示例源码

    **hibernate二级缓存详解** Hibernate作为Java领域中广泛使用的对象关系映射(ORM)框架,极大地简化了数据库操作。然而,在处理大量数据时,性能优化显得尤为重要,这就是二级缓存的作用。本文将深入探讨Hibernate...

    Hibernate 二级缓存 总结整理

    **Hibernate 二级缓存总结整理** 在Java的持久化框架中,Hibernate是一个广泛使用的ORM(对象关系映射)工具,它极大地简化了数据库操作。在处理大数据量或高并发的场景下,为了提高性能和减少数据库负载,...

    hibernate二级缓存包

    Hibernate二级缓存是Java开发中使用Hibernate框架进行数据持久化时优化性能的一种重要技术。它在一级缓存(Session级别的缓存)的基础上,提供了一个全局的、跨会话的数据存储层,可以显著减少对数据库的访问,从而...

    hibernate二级缓存java包下载

    二级缓存是 Hibernate 缓存策略的一部分,它在应用程序的多个会话之间共享数据,进一步优化了数据库访问效率。 二级缓存分为以下关键知识点: 1. **一级缓存与二级缓存的区别**: - 一级缓存:每个 Hibernate ...

    hibernate 二级缓存

    本篇文章将深入探讨Hibernate二级缓存的概念、工作原理以及如何在实际项目中设置和使用。 **一、二级缓存概念** 一级缓存是每个Hibernate Session内部的一个内存区域,用于存储Session期间的操作对象。当Session...

    hibernate二级缓存所需要的 jar包

    本篇将详细介绍Hibernate二级缓存的概念、作用以及所需jar包的作用。 一、Hibernate二级缓存概念 Hibernate的一级缓存是指Session级别的缓存,每个Session内部都有一个一级缓存,用于存储实体对象,当Session关闭时...

    day37 05-HIbernate二级缓存:一级缓存更新同步到二级缓存及二级缓存配置文件

    本篇文章将深入探讨Hibernate的二级缓存机制,以及如何进行一级缓存与二级缓存的同步,同时还会介绍二级缓存的配置文件设置。 一级缓存是Hibernate默认提供的缓存,每个SessionFactory实例都有一个一级缓存。当对象...

Global site tag (gtag.js) - Google Analytics