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個數據庫的連接,這樣會極大的降低性能。