分享一下我老师大神的人工智能教程!零基础,通俗易懂!http://blog.csdn.net/jiangjunshow
也欢迎大家转载本篇文章。分享知识,造福人民,实现我们中华民族伟大复兴!
一级缓存
查询两次id为1的user
User user1 = entityManager.find(User.class, 1);User user2 = entityManager.find(User.class, 1);
- 1
- 2
结果发现只调用了一次sql查询,因为使用了一级缓存
如果查询一次后,关掉entityManager,再查询
User user1 = entityManager.find(User.class, 1);entityManager.close();entityManager = factory.createEntityManager();User user2 = entityManager.find(User.class, 1);
- 1
- 2
- 3
- 4
- 5
- 6
发现查询了两次,因为entityManager关闭之后,缓存也就没有了。
使用二级缓存
所谓的二级缓存,也就是可以跨entityManager的缓存,也就是说:就算你关闭了entityManager,缓存也依然在。
在配置文件persistence.xml中配置
<!-- 二级缓存相关 --><property name="hibernate.cache.use_second_level_cache" value="true"/><property name="hibernate.cache.region.factory_class" value="org.hibernate.cache.ehcache.EhCacheRegionFactory"/><property name="hibernate.cache.use_query_cache" value="true"/>
- 1
- 2
- 3
- 4
缓存需要以下jar包:
在src下加入一个配置文件:ehcache.xml,这个文件直接拷贝来用就行了,不用理会里面的内容,有需要的时候再研究也不迟
<ehcache> <!-- Sets the path to the directory where cache .data files are created. If the path is a Java System Property it is replaced by its value in the running VM. The following properties are translated: user.home - User's home directory user.dir - User's current working directory java.io.tmpdir - Default temp file path --> <diskStore path="java.io.tmpdir"/> <!--Default Cache configuration. These will applied to caches programmatically created through the CacheManager. The following attributes are required for defaultCache: maxInMemory - Sets the maximum number of objects that will be created in memory eternal - Sets whether elements are eternal. If eternal, timeouts are ignored and the element is never expired. timeToIdleSeconds - Sets the time to idle for an element before it expires. Is only used if the element is not eternal. Idle time is now - last accessed time timeToLiveSeconds - Sets the time to live for an element before it expires. Is only used if the element is not eternal. TTL is now - creation time overflowToDisk - Sets whether elements can overflow to disk when the in-memory cache has reached the maxInMemory limit. --> <defaultCache maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true" /> <!--Predefined caches. Add your cache configuration settings here. If you do not have a configuration for your cache a WARNING will be issued when the CacheManager starts The following attributes are required for defaultCache: name - Sets the name of the cache. This is used to identify the cache. It must be unique. maxInMemory - Sets the maximum number of objects that will be created in memory eternal - Sets whether elements are eternal. If eternal, timeouts are ignored and the element is never expired. timeToIdleSeconds - Sets the time to idle for an element before it expires. Is only used if the element is not eternal. Idle time is now - last accessed time timeToLiveSeconds - Sets the time to live for an element before it expires. Is only used if the element is not eternal. TTL is now - creation time overflowToDisk - Sets whether elements can overflow to disk when the in-memory cache has reached the maxInMemory limit. --> <!-- Sample cache named sampleCache1 This cache contains a maximum in memory of 10000 elements, and will expire an element if it is idle for more than 5 minutes and lives for more than 10 minutes. If there are more than 10000 elements it will overflow to the disk cache, which in this configuration will go to wherever java.io.tmp is defined on your system. On a standard Linux system this will be /tmp" --> <cache name="sampleCache1" maxElementsInMemory="10000" eternal="false" timeToIdleSeconds="300" timeToLiveSeconds="600" overflowToDisk="true" /> <!-- Sample cache named sampleCache2 This cache contains 1000 elements. Elements will always be held in memory. They are not expired. --> <cache name="sampleCache2" maxElementsInMemory="1000" eternal="true" timeToIdleSeconds="0" timeToLiveSeconds="0" overflowToDisk="false" /> --> <!-- Place configuration for your caches following --></ehcache>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
- 10
- 11
- 12
- 13
- 14
- 15
- 16
- 17
- 18
- 19
- 20
- 21
- 22
- 23
- 24
- 25
- 26
- 27
- 28
- 29
- 30
- 31
- 32
- 33
- 34
- 35
- 36
- 37
- 38
- 39
- 40
- 41
- 42
- 43
- 44
- 45
- 46
- 47
- 48
- 49
- 50
- 51
- 52
- 53
- 54
- 55
- 56
- 57
- 58
- 59
- 60
- 61
- 62
- 63
- 64
- 65
- 66
- 67
- 68
- 69
- 70
- 71
- 72
- 73
- 74
- 75
- 76
- 77
- 78
- 79
- 80
- 81
- 82
- 83
- 84
- 85
- 86
- 87
- 88
- 89
启用二级缓存:
1.在实体类上加注解@Cacheable(true)
@Cacheable(true)@Table(name="T_USER")@Entitypublic class User ...
- 1
- 2
- 3
- 4
2.在配置文件persistence.xml中配置二级缓存的策略
<!-- 配置二级缓存的策略 ALL:所有的实体类都被缓存NONE:所有的实体类都不被缓存. ENABLE_SELECTIVE:标识 @Cacheable(true) 注解的实体类将被缓存DISABLE_SELECTIVE:缓存除标识 @Cacheable(false) 以外的所有实体类UNSPECIFIED:默认值,JPA 产品默认值将被使用--><shared-cache-mode>ENABLE_SELECTIVE</shared-cache-mode>
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9
注意:这个配置要放在provider 节点和class 节点后面
再次执行
User user1 = entityManager.find(User.class, 1);entityManager.close();entityManager = factory.createEntityManager();User user2 = entityManager.find(User.class, 1);
- 1
- 2
- 3
- 4
- 5
- 6
结果只调用了一次sql查询语句,说明二级缓存 起作用了。