二級緩存及外部緩存,它能夠越過數個Session,通過同一個SessionFactory進行管理和維護。

要使用二級緩存,首先需要對hibernate.cfg.xml文件進行修改:

  1. <?xml version="1.0" encoding="utf-8"?> 
  2. <!DOCTYPE hibernate-configuration PUBLIC
  3.     "-//Hibernate/Hibernate Configuration DTD 3.0//EN"
  4.     "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">
  5.     
  6. <hibernate-configuration> 

  7.     <session-factory> 

  8.         ....
  9.         <property name="hibernate.cache.provider_class">
  10.             org.hibernate.cache.HashtableCacheProvider
  11.         </property>
  12.         ....
  13.         
  14.     </session-factory> 

  15. </hibernate-configuration>

HashtableCache是Hibernate自己所提供的二級緩存的實現,但是由于其性能和功能有限,一般只用于開發和測試。

當然我們可以使用第三方的實現,譬如:org.hibernate.cache.EhCacheProvider,這個需要ehcathe.jar包。

修改User.hbm.xml文件:

  1. <?xml version="1.0" encoding="utf-8"?>
  2. <!DOCTYPE hibernate-mapping 
  3.     PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN" 
  4.     "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">

  5. <hibernate-mapping> 

  6.     <class name="com.hb3.pack_21.model.User" table="user">
  7.     
  8.         <cache usage="read-write"/>
  9.     
  10.         <id name="id" column="id" type="java.lang.Integer"> 
  11.             <generator class="native"/> 
  12.         </id> 

  13.         <property name="name" column="name" type="java.lang.String"/> 
  14.         
  15.         <many-to-one name="room" 
  16.                      column="room_id" 
  17.                      class="com.hb3.pack_21.model.Room"
  18.                      cascade="save-update"
  19.                      outer-join="true"/> 
  20.         
  21.     </class> 

  22. </hibernate-mapping>

這里追加的策略有read-only、read-write、nonstrict-read-write以及transactional。不同的第三方緩存實現所支持的種類是不同的,請參閱:http://www.hibernate.org/hib_docs/v3/reference/en/html/performance.html#performance-cache

 

在工程的classpath下追加ehcache.xml文件,內容為:

  1. <ehcache>

  2.    <diskStore path="java.io.tmpdir"/>

  3.    <defaultCache
  4.         maxElementsInMemory="10000"
  5.         eternal="false"
  6.         timeToIdleSeconds="120"
  7.         timeToLiveSeconds="120"
  8.         overflowToDisk="true"
  9.         />
  10.         
  11. </ehcache>

測試代碼如下:

  1. package com.hb3.pack_21;

  2. import java.io.IOException;
  3. import java.sql.SQLException;

  4. import org.hibernate.Session;
  5. import org.hibernate.SessionFactory;
  6. import org.hibernate.cfg.Configuration;

  7. import com.hb3.pack_21.model.User;

  8. public class BusinessService {

  9.     public static void main(String[] args) throws IOException, SQLException {
  10.         
  11.         Configuration config = new Configuration().configure();
  12.         SessionFactory sessionFactory = config.buildSessionFactory();      
  13.         Session session = sessionFactory.openSession();

  14.         
  15.         User user1 = (User) session.load(User.classnew Integer(1));
  16.         user1.getName();
  17.         
  18.         session.close();
  19.         session = sessionFactory.openSession();
  20.         
  21.         User user2 = (User) session.load(User.classnew Integer(1));
  22.         user2.getName();


  23.         session.close();
  24.         sessionFactory.close();
  25.     }
  26. }

如果不使用二級緩存機制,生成的SQL文為:

Hibernate:
select user0_.id as id0_, user0_.name as name0_0_, user0_.age as age0_0_
from user user0_ where user0_.id=?
Hibernate:
select user0_.id as id0_, user0_.name as name0_0_, user0_.age as age0_0_
from user user0_ where user0_.id=?

 

使用后,第二級做相同的查詢會從二級緩存中讀取。

當然,如果打算從二級緩存中清空對象的緩存信息,可以使用SessionFactory的evict()方法,如:

sessionFactory.evict(User.class, user.getId());



ExtJS教程- Hibernate教程-Struts2 教程-Lucene教程