1.一级缓存:同一个EntityManager不用重复从数据库中查询同一个数据
2.二级缓存:命中条件:同一个EntityManagerFactory,不同的EntityManager,同一个OID
开启条件
1.导入jar包
<dependency>
<groupId>org.hibernate</groupId>
<artifactId>hibernate-ehcache</artifactId>
<version>4.3.8.Final</version>
</dependency>
2.在pesistence.xml中完成配置
<!-- 启用二级缓存 -->
<property name="hibernate.cache.use_second_level_cache" value="true" />
<!-- 二级缓存的实现类,文档里面的包名有错的 -->
<!-- 错误 org.hibernate.cache.internal.EhCacheRegionFactory -->
<!-- 正确的 org.hibernate.cache.ehcache.EhCacheRegionFactory -->
<property name="hibernate.cache.region.factory_class" value="org.hibernate.cache.ehcache.EhCacheRegionFactory" />
<!-- 启用查询缓存 -->
<property name="hibernate.cache.use_query_cache" value="true" />
3.在实体类中加上@Cacheable
Test:
@Test
public void testCatch() throws Exception {
EntityManager manager = EmUtil.getManager();
Student student = manager.find(Student.class, 1L);
System.out.println(student.getName());
EmUtil.CLose(manager);
EntityManager manager2 = EmUtil.getManager();
Student student2 = manager2.find(Student.class, 1L);
System.out.println(student2.getName());
EmUtil.CLose(manager2);
}
适用场景
1.查询多于增删改
2.财务金融等敏感数据不适合
3.数据量太大不适合
4.数据库被多方系统增删改不适合