参考文章:
http://www.jianshu.com/p/6f357c4cc0f7 (Hibernate @Cache 注解)
@Cache 定义了二级缓存策略和缓存范围
一、属性
1:usage: 当前缓存策略(NONE, READ_ONLY, NONSTRICT_READ_WRITE, TRANSACTIONAL)。
(1)read-only: 只读缓存
如果你的应用程序只需读取一个持久化类的实例,而无需对其修改, 那么就可以对其进行只读缓存
(2)read-write: 读写缓存
如果应用程序需要更新数据,那么使用读/写缓存比较合适。 如果应用程序要求“序列化事务”的隔离级别(serializable transaction isolation level),那么就决不能使用这种缓存策略
(3)nonstrict-read-write: 不严格读写缓存
如果应用程序只偶尔需要更新数据(也就是说,两个事务同时更新同一记录的情况很不常见),也不需要十分严格的事务隔离,那么比较适合使用非严格读/写缓存策略。
(4)transactional :事务性缓存
Hibernate 的事务缓存策略提供了全事务的缓存支持,例如对 JBoss TreeCache 的支持。这样的缓存只能用于 JTA 环境中,你必须指定为其hibernate.transaction.manager_lookup_class属性。
2:region: 可选参数,指定二级缓存的去域名,默认为类或者集合的名字。
3:include: 可选参数(all, non-lazy)。all包含所有属性,non-lazy仅包含非延迟加载的属性。
二、缓存实例
1:缓存实体
@Table(name = "PROVICE")
@Cache(usage =CacheConcurrencyStrategy.READ_ONLY)
public class Province() {
...
}
2:缓存集合
@Table(name = "PROVICE")
@Cache(usage =CacheConcurrencyStrategy.READ_ONLY)
public class Province() {//省份对象
@OneToMany(fetch = FetchType.LAZY)
@JoinColumn(name = "cityId")
@Cache(usage = CacheConcrrencyStrategy.READ_ONLY)
private Set<City> cities; //省份对应城市
}
此时在访问province.cities时,Hibernate 只缓存了city的OID,因此在实际查询过程中还是需要执行
select * from city where cityid = ?
为了避免该问题,可以为City对象同样配置二级缓存@Table(name = "CITY")
@Cache(usage =CacheConcurrencyStrategy.READ_ONLY)
public class City() {//城市对象
...
}