快速业务通道

hibernate3学习笔记(二十一)|二级缓存 - 编程入门网

作者 佚名技术 来源 NET编程 浏览 发布时间 2012-06-19

hibernate3学习笔记(二十一)|二级缓存

时间:2011-02-03

二级缓存及外部缓存,它能够越过数个Session,通过同一个SessionFactory进行管理和维护。

接上例的代码:http://blog.csdn.net/kunshan_shenbin/archive/2008/09/03/2874375.aspx

要使用二级缓存,首先需要对hibernate.cfg.xml文件进行修改:

1.<?xml version="1.0" encoding="utf-8"?>2.<!DOCTYPE hibernate-configuration PUBLIC3.    "-//Hibernate/Hibernate Configuration DTD 3.0//EN"4.    "http://hibernate.sourceforge.net/hibernate-configuration-3.0.dtd">5.6.<hibernate-configuration>7.8.    <session-factory>9.10.        ....11.        <property name="hibernate.cache.provider_class">12.            org.hibernate.cache.HashtableCacheProvider13.        </property>14.        ....15.16.    </session-factory>17.18.</hibernate-configuration>

HashtableCache是Hibernate自己所提供的二级缓存的实现,但是由于其性能和功能有限,一般只用于开发和测试。

当然我们可以使用第三方的实现,譬如:org.hibernate.cache.EhCacheProvider,这个需要ehcathe.jar包。

修改User.hbm.xml文件:

1.<?xml version="1.0" encoding="utf-8"?>2.<!DOCTYPE hibernate-mapping3.    PUBLIC "-//Hibernate/Hibernate Mapping DTD 3.0//EN"4.    "http://hibernate.sourceforge.net/hibernate-mapping-3.0.dtd">5.6.<hibernate-mapping>7.8.    <class name="com.hb3.pack_21.model.User" table="user">9.10.        <cache usage="read-write"/>11.12.        <id name="id" column="id" type="java.lang.Integer">13.            <generator class="native"/>14.        </id>15.16.        <property name="name" column="name" type="java.lang.String"/>17.18.        <many-to-one name="room"19.                     column="room_id"20.                     class="com.hb3.pack_21.model.Room"21.                     cascade="save-update"22.                     outer-join="true"/>23.24.    </class>25.26.</hibernate-mapping>

hibernate3学习笔记(二十一)|二级缓存(2)

时间:2011-02-03

这里追加的策略有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.3.   <diskStore path="java.io.tmpdir"/>4.5.   <defaultCache6.        maxElementsInMemory="10000"7.        eternal="false"8.        timeToIdleSeconds="120"9.        timeToLiveSeconds="120"10.        overflowToDisk="true"11.        />12.13.</ehcache>

测试代码如下:

1.package com.hb3.pack_21;2.3.import java.io.IOException;4.import java.sql.SQLException;5.6.import org.hibernate.Session;7.import org.hibern

凌众科技专业提供服务器租用、服务器托管、企业邮局、虚拟主机等服务,公司网站:http://www.lingzhong.cn 为了给广大客户了解更多的技术信息,本技术文章收集来源于网络,凌众科技尊重文章作者的版权,如果有涉及你的版权有必要删除你的文章,请和我们联系。以上信息与文章正文是不可分割的一部分,如果您要转载本文章,请保留以上信息,谢谢!

分享到: 更多

Copyright ©1999-2011 厦门凌众科技有限公司 厦门优通互联科技开发有限公司 All rights reserved

地址(ADD):厦门软件园二期望海路63号701E(东南融通旁) 邮编(ZIP):361008

电话:0592-5908028 传真:0592-5908039 咨询信箱:web@lingzhong.cn 咨询OICQ:173723134

《中华人民共和国增值电信业务经营许可证》闽B2-20100024  ICP备案:闽ICP备05037997号