0

我有以下映射实体:

@Table(uniqueConstraints = @UniqueConstraint(columnNames = { "eKey-field-1", "eKey-field-2", "eKey-field-3" }))
class EntityMapped {
    @Id
    @GeneratedValue...
    Long Id;

    @Embedded
    EntityKeyMapped eKey;

没有更新也没有删除。如果给定的 eKey 没有安全性,则添加新记录。

选择查询非常简单,但每天最多并行执行 1+ Mln 查询(+有时会添加新记录)。所以我想以某种方式缓存它。

在道中,我看到了类似的东西:

return (EntityMapped) getSession().createCriteria(EntityMapped.class).add(Example.create(example)).uniqueResult();

我正在考虑缓存此请求的最佳方法。Atm 我认为:

return (EntityMapped) getSession().createCriteria(EntityMapped.class).add(Example.create(example)).setCacheable(true).uniqueResult();

但也许对于这种情况,有更好(更简单)的缓存方式?

4

1 回答 1

1

您正在以正确的方式启用缓存。这是 Hibernate 团队设计的方式。

如果您使用的是 spring(或 com.googlecode.ehcache.annotations 等),您可以通过在方法上添加注释来启用缓存。但这将在休眠之外。

使用纯休眠时,您的解决方案是正确的。

要记住的一件事是,您可以启用缓存并设置要使用的正确区域

return (SecurityMapped) getSession()
  .createCriteria(SecurityMapped.class)
  .add(Example.create(example))
  .setCacheable(true)
  .setCacheRegion("myregion")   // here you can choose region
  .uniqueResult();

然后在您的缓存提供程序配置文件中,您可以配置不同的区域。

例如在EhCache配置中,您可以"myregion"这样设置:

<ehcache ...>

    <cache name="myregion" 
           maxElementsInMemory="1000" 
           eternal="false" 
           timeToIdleSeconds="3600" 
           timeToLiveSeconds="7200" 
           overflowToDisk="false" 
           memoryStoreEvictionPolicy="LFU"/>

</ehcache>
于 2015-05-28T16:36:13.850 回答