JPA2.0 缓存 之 Cache 注解的使用

如果要使用缓存, 必须在persistence.xml文件中设定

<property name="hibernate.cache.provider_class" value="org.hibernate.cache.EhCacheProvider"/> <property name="hibernate.cache.use_second_level_cache" value="true"/> <property name="hibernate.cache.use_query_cache" value="true"/>

然后 Entity 需要

@Entity @Table(name="users") @Cache(usage=CacheConcurrencyStrategy.READ_ONLY) public class User {

@Cache(usage=CacheConcurrencyStrategy.READ_ONLY)


表示该Entity加入到CacheManager的管理下

em = emf.createEntityManager(); em.find(User.class, 1); em.find(User.class, 1); em.close(); System.out.println("----xxx----"); em = emf.createEntityManager(); em.find(User.class, 1); Query query = em.createQuery("from User"); if(query instanceof org.hibernate.ejb.QueryImpl<?>){ ((QueryImpl<?>) query).getHibernateQuery().setCacheable(true); } query.getResultList(); query.getResultList();

要使用查询缓存:主要设置

if(query instanceof org.hibernate.ejb.QueryImpl<?>){
((QueryImpl<?>) query).getHibernateQuery().setCacheable(true);
}

运行结果

=============

Hibernate: select user0_.id ...... from users user0_ where user0_.id=?
----xxx----
Hibernate: select user0_.id......from users user0_


===============

em.find

em.find

em.find

多个 em 在二级缓存中均有效,所以只执行一次

-----xxxxx-----

query.getResultList

query.getResultList

同样,由于查询缓存的作用,该查询也只执行一次

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值