`
yangzhibin_java
  • 浏览: 50943 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

hibernate 缓存

阅读更多

一,分类

       一级缓存---session

       二级缓存---sessionFactory

       查询缓存---生命周期不确定(如果有人更改了这张表,查询缓存立即失效)

 

二,基础知识

      2.1 一级和二级缓存不支持普通属性,查询缓存支持

      2.2 get(),load(),iterator() 这3种方法支持缓存

                Query,Criteria(查询缓存)由于命中率较低,所以hibernate缺省是关闭;

                        ①修改cache.use_query_cache true 打开对查询的缓存,

                        ②调用query.setCacheable(true) criteria.setCacheable(true)

                list()默认情况下每次都会发的,只要配置了查询缓存时它才不会发sql

     
      2.3 可以使用下面方法管理缓存

                 //管理一级缓存

                 session.evict(obj); ----一条记录(在使用uuid生成策略时。你手动调用该方法会报错

                 session.clear();----所有的

                 session.flush() --------会发uuid没发的sql语句(在调用evict或clear方法前,先调用该方法)

                         作用:可以改变sql语句的执行顺序 (hibernate默认是save,update,delete

 

                 //管理二级缓存

                 sessionFactory.evict(User.class); ----所有的该类型对象

                 sessionFactory.evict(User.class,12); ----一条记录

 

 

      2.4 往缓存里添加数据(有很多方法可以往缓存中添加数据)

                   二级缓存 添加数据时,save方法不适合native生成方式的主键

      2.5 查询缓存缓存了实体的id,二级缓存缓存了实体

 

三,一级缓存 (一级缓存可以理解为session对象的一个map)

 

 

四,二级缓存

 

       1.配置

<!--开启二级缓存-->
<property name="hibernate.cache.use_second_level_cache">true</property>
<property name="cache.provider_class">org.hibernate.cache.OSCacheProvider </property>

<!--hibernate.cfg.xml里配置-->
<class-cache class="yangzhibin.User" user="read-only "/>
<!--User.hbm.xml里配置-->
<cache usage="read-write "/>

        2.usage(策略)取值:

            read-only 效率最高,但是对象不能修改,修改了会报异常(如:省市表)

            read-write:严格的读写(如:银行)

            nonstrict-read-write:不严格的读写(如:帖子的回帖量)效率高点

            transactional:一般缓存没这个功能(jboss-cache实现了,oscache不提供这个功能)          

 

五,一级缓存和二级缓存交互

session.setCacheMode(CacheMode.GET ); //仅向二级缓存 数据,而不向二级缓存 数据

session.setCacheMode(CacheMode.PUT ); //只向二级缓存 数据,而不从二级缓存 数据

 

 

六,查询缓存(对 iterator() 不起作用)

    6.1生命周期

       当前关联的表发生修改,那么查询缓存生命周期结束

    6.2缓存的内容

       针对普通结果集,对实体对象的结果集只缓存id

    6.3配置(hibernate默认查询缓存时关闭 的)

      ① 通过下面方法启动

<!-- 启用查询缓存 -->
<property name="hibernate.cache.use_query_cache">true</property>

      ②在程序中启用查询缓存(只对query.list()起作用,对query.iterator()不起作用):

        query.setCacheable(true);

        criteria.setCacheable(true);

    6.4会发现奇异的情况

        1,query.list() 可能会发出n条语句(因为查询缓存开着了,所有hibernate在调用query.list()是不是发一条sql语句,而是根据实体类的id来一个一个查询)

 

 

 

 

 

 

 

分享到:
评论
2 楼 xiaohai0504 2013-11-20  
二级缓存没开
1 楼 kangzye 2012-10-30  
1,query.list() 可能会发出n条语句(因为查询缓存开着了,所有hibernate在调用query.list()是不是发一条sql语句,而是根据实体类的id来一个一个查询)

最后这个观点是错误的,依然是执行一条查询语句

相关推荐

Global site tag (gtag.js) - Google Analytics