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

本文详细介绍了如何在 JPA2.0 中配置和使用缓存,通过在 `persistence.xml` 文件设置 `hibernate.cache.provider_class`, `hibernate.cache.use_second_level_cache` 和 `hibernate.cache.use_query_cache` 属性启用缓存。接着展示了在 `@Entity` 类上使用 `@Cache(usage=CacheConcurrencyStrategy.READ_ONLY)` 注解将实体纳入缓存管理。文章还给出了示例代码,展示如何通过 `em.find()` 方法和查询语句利用缓存,以及如何设置查询缓存。通过这些配置和注解,可以明显减少数据库查询次数,提高应用性能。" 102618858,9105473,C++实现HDU2032杨辉三角与二维数组应用,"['C++编程', '算法', '数据结构', '在线判题', '二维数组应用']

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

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

 

[xhtml]  view plain copy
  1. <property name="hibernate.cache.provider_class" value="org.hibernate.cache.EhCacheProvider"/>  
  2.             <property name="hibernate.cache.use_second_level_cache" value="true"/>  
  3.             <property name="hibernate.cache.use_query_cache" value="true"/>  

 

然后 Entity 需要

 

[java]  view plain copy
  1. @Entity  
  2. @Table(name="user")  
  3. @Cache(usage=CacheConcurrencyStrategy.READ_ONLY)  
  4. public class User {  

 

@Cache(usage=CacheConcurrencyStrategy.READ_ONLY)


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

 

[java]  view plain copy
  1. em = emf.createEntityManager();  
  2.     em.find(User.class1);  
  3.     em.find(User.class1);  
  4.     em.close();  
  5.     System.out.println("----xxx----");  
  6.     em = emf.createEntityManager();  
  7.     em.find(User.class1);  
  8.       
  9.     Query query = em.createQuery("from User");  
  10.     if(query instanceof org.hibernate.ejb.QueryImpl<?>){  
  11.         ((QueryImpl<?>) query).getHibernateQuery().setCacheable(true);  
  12.     }   
  13.   
  14.     query.getResultList();  
  15.     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

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

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值