詳解Hibernate注解方式的二級緩存
hibernate默認情況下是支持一級緩存,也就是session級的緩存的,而默認情況下是不支持二級緩存,即sessionFactory級的緩存的,二級緩存 一般比較少去考慮它,除非對效率要求非常高的時候,
這時侯如果我們的某一個實體要在多個session里面使用需要用到session間的緩存的時候就可以進行配置來實現二級緩存了!
在看文檔的時候說可以在persistence.xml里面進行配置,但我一般是不用這個文件的,就直接使用注解!
在使用二級緩存之前需要先開啟二級緩存的功能,否則不能使用;
具體做法是在hibernate的配置文件里面加上
property name="cache.use_second_level_cache">true/property>
property name="cache.provider_class">net.sf.ehcache.hibernate.EhCacheProvider/property>
此外還需要導入ehcache.jar包
一般就是如果哪個類需要使用到二級緩存就在該類上加上注解@cacheable,這就表明該類是支持二級緩存的,此外,還可以通過@cache注解來選擇緩存策略,緩存策略主要有四種,分別是:
- read-only
- read-write
- nonstrict-read-write
- transactional
用法類似于這樣:
@Cache(usage=CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
此外@cache注解還可以用于包含其他實體類的集合類屬性,這樣該集合也會緩存起來!
示例:
//實體類@cacheable
@Entity @Cacheable
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
public class Forest { ... }
//集合類@cache
@OneToMany(cascade=CascadeType.ALL, fetch=FetchType.EAGER)
@JoinColumn(name="CUST_ID")
@Cache(usage = CacheConcurrencyStrategy.NONSTRICT_READ_WRITE)
public SortedSetTicket> getTickets() {
return tickets;
}
測試:
@Test
public void testFind() {//Model1是使用了二級緩存的,這里只會發出一條sql語句
Session session = factory.openSession();
Model1 model = (Model1)session.get(Model1.class, 1);
System.out.println(model.getId());
Session session2 = factory.openSession();
Model1 model2 = (Model1)session2.get(Model1.class, 1);
System.out.println(model2.getId());
session.close();
session2.close();
}
@Test
public void testFind2() {//Model2沒有進行二級緩存,所以這里會發出兩條sql語句
Session session = factory.openSession();
Model2 model = (Model2)session.get(Model2.class, 1);
System.out.println(model.getId());
Session session2 = factory.openSession();
Model2 model2 = (Model2)session2.get(Model2.class, 1);
System.out.println(model2.getId());
session.close();
session2.close();
}
@Cache用于集合類屬性:
@Test
public void testFind4() {
//在沒有給Model1里面的models加上二級緩存的注解@Cache之前,
//不同的Session里面的同一個對象使用models的時候會發出多條sql語句
//而加上了@Cache之后,下面只會發出一條SQL語句
Session session = factory.openSession();
Model1 model = (Model1)session.get(Model1.class, 1);
ListModel2> models = model.getModels();
for (Model2 mode2: models) {
System.out.println(mode2.getId());
}
Session session2 = factory.openSession();
Model1 model1 = (Model1)session2.get(Model1.class, 1);
ListModel2> models2 = model1.getModels();
for (Model2 model2: models2) {
System.out.println(model2.getId());
}
session.close();
session2.close();
}
@OneToMany(mappedBy="model1")
@Cache(usage=CacheConcurrencyStrategy.READ_ONLY)
public ListModel2> getModels() {
return models;
}
感謝閱讀,希望能幫助到大家,謝謝大家對本站的支持!
您可能感興趣的文章:- 詳細解讀Hibernate的緩存機制
- hibernate查詢緩存詳細分析
- JSP 開發之hibernate配置二級緩存的方法
- 詳解spring boot集成ehcache 2.x 用于hibernate二級緩存
- java中hibernate二級緩存詳解
- 詳解Hibernate緩存與性能優化
- Spring 整合 Hibernate 時啟用二級緩存實例詳解
- Hibernate緩存機制實例代碼解析