配置
在二級緩存配置成功的基礎(chǔ)上進行查詢緩存配置
模型對象Product
public class Product {
private Long id;
private String name;
映射文件Product.hbm.xml
<class name="Product">
<id name="id">
<generator class="native" />
</id>
<property name="name" />
</class>
測試對象MainTest
public class MainTest {
@Before
public void save() throws Exception {
Product product = new Product();
product.setName("xxxx");
Session session = HibernateUtils.INSTANCE.getSession();
session.beginTransaction();
session.save(product);
session.getTransaction().commit();
session.close();
}
// 模擬同一個SessionFactory,不同session獲取hql查詢
// 查詢緩存需要先配置類的二級緩存
// 只發(fā)出一條sql:查詢緩存命中
@Test
public void get() throws Exception {
Session session1 = HibernateUtils.INSTANCE.getSession();
String hql = "select p from Product p";
Query query = session1.createQuery(hql);
// 放入查詢緩存
query.setCacheable(true);
System.out.println(query.list().size());
session1.close();
Session session2 = HibernateUtils.INSTANCE.getSession();
String hql2 = "from Product";
Query query2 = session2.createQuery(hql2);
// 從查詢緩存取
query2.setCacheable(true);
System.out.println(query2.list().size());
session2.close();
}
}
其他關(guān)聯(lián)項目
-
Hibernate 菜鳥教程 15 一級緩存
http://blog.csdn.net/je_ge/article/details/53245036 -
Hibernate 菜鳥教程 16 二級緩存
http://blog.csdn.net/je_ge/article/details/53246155
源碼地址
https://github.com/je-ge/hibernate
如果覺得我的文章或者代碼對您有幫助,可以請我喝杯咖啡。
**您的支持將鼓勵我繼續(xù)創(chuàng)作!謝謝! **