0

我将 Hibernate 4.3.11.Final 与 ehcache 和 Spring 3.2.11.RELEASE 一起使用。我有以下 Spring/ehcache 配置……</p>

<cache:annotation-driven key-generator="cacheKeyGenerator" />

<bean id="cacheKeyGenerator" class="org.mainco.subco.myproject.util.CacheKeyGenerator" />

<bean id="cacheManager"
    class="org.springframework.cache.ehcache.EhCacheCacheManager"
    p:cacheManager-ref="ehcache"/>

<bean id="ehcache" class="org.springframework.cache.ehcache.EhCacheManagerFactoryBean"
    p:configLocation="classpath:ehcache.xml"
    p:shared="true" />

<util:map id="jpaPropertyMap">
    <entry key="hibernate.show_sql" value="true" />
    <entry key="hibernate.dialect" value="org.mainco.subco.myproject.jpa.subcoMysql5Dialect" />
    <entry key="hibernate.cache.region.factory_class" value="org.hibernate.cache.ehcache.EhCacheRegionFactory" />
    <entry key="hibernate.cache.provider_class" value="org.hibernate.cache.EhCacheProvider" />
    <entry key="hibernate.cache.use_second_level_cache" value="true" />
    <entry key="hibernate.cache.use_query_cache" value="false" />
    <entry key="hibernate.generate_statistics" value="true" />
    <entry key="javax.persistence.sharedCache.mode" value="ENABLE_SELECTIVE" />
</util:map>

<bean id="sharedEntityManager"
    class="org.springframework.orm.jpa.support.SharedEntityManagerBean">
    <property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>

<bean id="transactionManager" class="org.springframework.orm.jpa.JpaTransactionManager">
    <property name="entityManagerFactory" ref="entityManagerFactory" />
</bean>

使用下面的自定义密钥生成器……</p>

public class CacheKeyGenerator implements KeyGenerator 
{

    @Override
    public Object generate(final Object target, final Method method, 
      final Object... params) {

        final List<Object> key = new ArrayList<Object>();
        key.add(method.getDeclaringClass().getName());
        key.add(method.getName());

        for (final Object o : params) {
            key.add(o);
        }
        return key;
    } 
}

如您所见,键是根据类名、方法名和任何参数生成的。我的问题是,如果我想从我的二级缓存中删除所有缓存键的第一个条目(因为我的键是一个数组)是“org.mainco.subco.standards.repo.StandardsDao”的条目,我该怎么写@CacheEvict 规则?以下不起作用……</p>

@Caching(evict = { @CacheEvict(value="main", key="{'org.mainco.subco.standards.repo.StandardsDao'}")})
public int deleteCorrelationTypeContexts(String categoryId)

任何指导表示赞赏。一个限制是,不能选择使用多个二级缓存——我只能为这个应用程序使用一个(名为“main”的那个)。

4

2 回答 2

0

我遇到了同样的问题,还发现“这不是常见的缓存实现的工作方式”。

因此,您需要实现自己的缓存提供程序并覆盖您选择的实现中的任何“密钥匹配器”。

可以在这里找到 GuavaCache 示例的一个很好的答案。

于 2017-04-17T22:09:19.420 回答
0

简短的回答是,这不起作用。这不是@CacheEvict注释的工作方式。

而且大多数缓存实现本身甚至没有这样的 API。

于 2016-03-08T17:42:46.063 回答