一级缓存的更新会自动同步到二级缓存。

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

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

@SuppressWarnings("all")
@Test
// 将内存中的数据写到硬盘
public void demo7(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); List<Order> list = session.createQuery("from Order").list();//现在是查询所有的订单 一执行createQuery就会往二级缓存里面放但是它不会用
//所以它就会往硬盘上去写了。但是为什么硬盘上c:/ehcache下的数据文件是空的呢?因为程序执行的速度太快了然后就结束了。然后它没来得及往硬盘去写你的程序就结束了。
//加上断点,你给它点空闲的时间。它就会把多余的对象写到硬盘上了。
tx.commit();
}
    @Test
// 一级缓存的更新会同步到二级缓存:
public void demo6(){
Session session = HibernateUtils.getCurrentSession();
Transaction tx = session.beginTransaction(); Customer customer = (Customer) session.get(Customer.class, 1);//查询一号客户
customer.setCname("芙蓉");//customer.setCname是更新一级缓存,它可以同步到二级缓存.你的一级缓存一更新,它把二级缓存也更新了. tx.commit(); session = HibernateUtils.getCurrentSession();
tx = session.beginTransaction(); @SuppressWarnings("unused")
Customer customer2 = (Customer) session.get(Customer.class, 1);//是最新的数据呢?还是原来一级缓存中的数据?
//一级缓存的更新会同步到二级缓存.为了保证二级缓存的数据没有问题,它肯定会拿到最新的数据.
tx.commit();
}

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

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

<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">

    <diskStore path="c:/ehcache"/><!-- 如果你往硬盘上去写,目标硬盘的路径是java.io.tmpdir java.io.tmpdir是系统临时文件存放的路径 -->
<!-- 默认的cache可以对所有的持久化类(在hibernate.cfg.xml里面配置的持久化类) -->
<!-- 假设这里有好几段二级缓存的配置,但是我可能只想用某一个。那就可以通过名字去指定。但是也可以直接使用默认的配置 -->
<!-- 二级缓存也是内存中的一块区域。它能存放多少个对象呢? -->
<!-- maxElementsInMemory最大的元素在内存中的数量,默认是一万个--> <!-- maxElementsInMemory缓存中对象的最大数目 -->
<!-- eternal 设置对象是否是永久的 -->
<!--如果用cache标签就是给它设置一名字 -->
<!-- timeToIdleSeconds 空闲时间 -->
<!-- timeToLiveSeconds 存活的时间 -->
<!-- overflowToDisk 假设maxElementsInMemory="10000",数据库有两万条记录呢 超出内存的区域中是否到硬盘上 是否把你的内存中超出的部分写到硬盘上 超出内存的部分写到硬盘上 如果值为true,可以往硬盘上写了--> <defaultCache
maxElementsInMemory="5"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
overflowToDisk="true"
maxElementsOnDisk="10000000"
diskPersistent="false"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU"
/>
</ehcache>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">

    <diskStore path="c:/ehcache"/><!-- 如果你往硬盘上去写,目标硬盘的路径是java.io.tmpdir java.io.tmpdir是系统临时文件存放的路径 -->
<!-- 默认的cache可以对所有的持久化类(在hibernate.cfg.xml里面配置的持久化类) -->
<!-- 假设这里有好几段二级缓存的配置,但是我可能只想用某一个。那就可以通过名字去指定。但是也可以直接使用默认的配置 -->
<!-- 二级缓存也是内存中的一块区域。它能存放多少个对象呢? -->
<!-- maxElementsInMemory最大的元素在内存中的数量,默认是一万个--> <!-- maxElementsInMemory缓存中对象的最大数目 -->
<!-- eternal 设置对象是否是永久的 -->
<!--如果用cache标签就是给它设置一名字 -->
<!-- timeToIdleSeconds 空闲时间 -->
<!-- timeToLiveSeconds 存活的时间 -->
<!-- overflowToDisk 假设maxElementsInMemory="10000",数据库有两万条记录呢 超出内存的区域中是否到硬盘上 是否把你的内存中超出的部分写到硬盘上 超出内存的部分写到硬盘上 如果值为true,可以往硬盘上写了--> <defaultCache
maxElementsInMemory="5"
eternal="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
overflowToDisk="true"
maxElementsOnDisk="10000000"
diskPersistent="false"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU"
/>
</ehcache>
05-12 17:29