2

这是我的代码:

        SessionFactory sf = getSession().getSessionFactory();
        String query = "select r from RefEntity r where r.id in :ids";

        Session s1 = sf.openSession();
        s1.get(RefEntity.class, 1).getValue();
        s1.createQuery(query).setParameterList("ids", Arrays.asList(1, 2)).setCacheable(true).list();

        Session s2 = sf.openSession();
        s2.get(RefEntity.class, 1).getValue();
        s2.createQuery(query).setParameterList("ids", Arrays.asList(1, 2)).list();

安慰 :

Hibernate: 
    select
        refentity0_.id as id1_6_0_,
        refentity0_.value as value2_6_0_ 
    from
        RefEntity refentity0_ 
    where
        refentity0_.id=?
Hibernate: 
    /* select
        r 
    from
        RefEntity r 
    where
        r.id in :ids */ select
            refentity0_.id as id1_6_,
            refentity0_.value as value2_6_ 
        from
            RefEntity refentity0_ 
        where
            refentity0_.id in (
                ? , ?
            )
Hibernate: 
    /* select
        r 
    from
        RefEntity r 
    where
        r.id in :ids */ select
            refentity0_.id as id1_6_,
            refentity0_.value as value2_6_ 
        from
            RefEntity refentity0_ 
        where
            refentity0_.id in (
                ? , ?
            )

二级缓存有效,但我不明白为什么查询缓存不起作用。谁能解释一下是怎么回事??我会很感激的,谢谢 :)

我的实体:

@Table
@Entity
@Getter
@Setter
@ToString
@Cacheable
@org.hibernate.annotations.Cache(region = "dictionaryCache", usage = CacheConcurrencyStrategy.READ_ONLY)
public class RefEntity {

    @Id
    @GeneratedValue(strategy = GenerationType.SEQUENCE, generator = "ref_seq")
    @SequenceGenerator(name = "ref_seq", sequenceName = "ref_seq", allocationSize = 1)
    @Column(name = "id")
    private Integer id;

    @Column(name = "value")
    private String value;
}

持久性隐藏.xml:

<persistence version="2.0" xmlns="http://java.sun.com/xml/ns/persistence">

    <persistence-unit name="TEST">
        <provider>org.hibernate.jpa.HibernatePersistenceProvider</provider>
        <shared-cache-mode>ENABLE_SELECTIVE</shared-cache-mode>

        <properties>
            <property name="hibernate.dialect" value="org.hibernate.dialect.PostgreSQL82Dialect"/>
            <property name="hibernate.show_sql" value="true"/>
            <property name="hibernate.format_sql" value="true"/>
            <property name="hibernate.use_sql_comments" value="true"/>
            <property name="hibernate.hbm2ddl.auto" value="update"/>

            <!-- cache -->
            <property name="hibernate.cache.provider_class" value="org.hibernate.cache.EhCacheProvider"/>
            <property name="hibernate.cache.use_query_cache" value="true"/>
            <property name="hibernate.cache.use_second_level_cache" value="true"/>
            <property name="net.sf.ehcache.configurationResourceName" value="ehcache.xml"/>
            <property name="hibernate.cache.region.factory_class"
                      value="org.hibernate.cache.ehcache.EhCacheRegionFactory"/>
        </properties>

    </persistence-unit>
</persistence>

ehcache.xml:

<cache name="dictionaryCache"
       maxElementsInMemory="10000"
       eternal="true"
       timeToIdleSeconds="600"
       timeToLiveSeconds="3600"
       overflowToDisk="false">
</cache>

<cache name="org.hibernate.cache.internal.StandardQueryCache"
       maxElementsInMemory="500"
       eternal="false"
       timeToIdleSeconds="600"
       timeToLiveSeconds="3600"/>

<cache name="org.hibernate.cache.spi.UpdateTimestampsCache"
       maxElementsInMemory="50"
       eternal="true"/>

maven依赖:

        <dependency>
            <groupId>net.sf.ehcache</groupId>
            <artifactId>ehcache-core</artifactId>
            <version>2.6.9</version>
        </dependency>
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-ehcache</artifactId>
            <version>5.0.0.Final</version>
        </dependency>
4

0 回答 0