hibernate的缓存
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23 |
<bean id= "sessionFactory" class = "org.springframework.orm.hibernate3.LocalSessionFactoryBean" > <property name= "dataSource" > <ref bean= "dataSource"
/> </property> <property name= "hibernateProperties" > <value> hibernate.show_sql= true hibernate.dialect=org.hibernate.dialect.MySQL5Dialect hibernate.cache.use_query_cache= true hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider </value> </property> <property name= "mappingResources" > <list> <value>net/spring/bo/User.hbm.xml</value> <value>net/spring/bo/Address.hbm.xml</value> <value>net/spring/bo/ClassName.hbm.xml</value> <value>net/spring/bo/Student.hbm.xml</value> </list> </property> </bean> |
众所周知hibernate有两级缓存,分别为session级别和sessionFactory级别。session级别缓存为一级缓存,只能一个线程用。在hibernate中默认是打开的,也就是我们无须打开。现在主要讨论hibernate的二级缓存,即sessionFactory级别缓存。
sessionFactory是默认关闭的。打开二级缓存需要在hibernate配置文件或者Spring(如果是配置了Spring框架)中打开。以applicationContext为例。
hibernate.cache.use_query_cache=true是打开二级缓存。 hibernate.cache.provider_class=org.hibernate.cache.EhCacheProvider为使用二级缓存的种类。hibernate二级缓存种类有好几种方法。
然后在bo类的配置文件中还需要 <cache usage="read-only"/> 只读缓存
然后再次两个不同的Session查询get或者load的时候只会出现一条sql语句。即可以证明是从缓存中查询出来。
hibernate的缓存默认的是智能根据Id查询。如果使用iterate则会出现N+1的问题。hibernate有查询缓存即 List it =
s1.createQuery("From User u where u.id
<10")
.setCacheable(true)
.list();
设置为true即可放入放入缓存中。但是如果查询条件变了查询缓存就不起作用。如果From User u where u.id <8。缓存就不起作用。
一般建议使用第三方缓存框架。
郑重声明:本站内容如果来自互联网及其他传播媒体,其版权均属原媒体及文章作者所有。转载目的在于传递更多信息及用于网络分享,并不代表本站赞同其观点和对其真实性负责,也不构成任何其他建议。