我在我們的使用Spring和Hibernate的Java應用程序上設置了ehcache。 然而,當我運行JUnit測試,並打印統計數據,似乎沒有什麼緩存:EHCache似乎不起作用
ON EVERY CACHE緩存管理器STATS輸出:。
COM **** SERVICES.CLARITY.DOMAIN .ACTIONITEM.BYRESOURCEUNIQUENAME: getCacheHits:0 getCacheMisses:0 getObjectCount:0
COM **** SERVICES.CLARITY.DOMAIN.ACTIONITEM: getCacheHits:0 getCacheMisses:0 getObjectCount:0
COM **** SERVICES.CLARITY.DOMAIN.RESOURCE:。 getCacheHits:0 getCacheMisses:0 getObjectCount:0
CONTENT映射文件(僅限零件,大到PASTE全部):
<class name="ActionItem" table="CAL_ACTION_ITEMS" mutable="false" lazy="false" >
<cache region="com.****.services.clarity.domain.ActionItem" usage="read-only" include="all" />
[...]
<query name="byResourceUniqueName" cacheable="true" cache-region="com.****.services.clarity.domain.ActionItem.byResourceUniqueName" read-only="true">
FROM ActionItem WHERE id IN (
SELECT DISTINCT actionItemId FROM ActionItemAssignee as aia WHERE assigneeId IN (
SELECT userId FROM Resource WHERE uniqueName = :uniqueName
)
)
ORDER BY dueDate
</query>
內容ehcache.xml中的:
<cache
name="com.****.services.clarity.domain.ActionItem"
maxElementsInMemory="2000" eternal="false" timeToIdleSeconds="0"
timeToLiveSeconds="600" overflowToDisk="false" />
<cache
name="com.****.services.clarity.domain.ActionItem.byResourceUniqueName"
maxElementsInMemory="2000" eternal="false" timeToIdleSeconds="0"
timeToLiveSeconds="60" overflowToDisk="false" />
<defaultCache maxElementsInMemory="200" eternal="false"
timeToIdleSeconds="120" timeToLiveSeconds="120" overflowToDisk="true"
memoryStoreEvictionPolicy="LRU" />
HIBERNATE CONFIG:
<property name="hibernateProperties">
<value>
hibernate.format_sql=true
hibernate.dialect=org.hibernate.dialect.OracleDialect
hibernate.cache.provider_class=net.sf.ehcache.hibernate.EhCacheProvider
hibernate.cache.use_query_cache=true
hibernate.show_sql=true
</value>
</property>
</bean>
如何填充緩存任何想法? 謝謝。