hibernate 缓存

来源:互联网 发布:雷姆雷姆软件汉化 编辑:程序博客网 时间:2024/06/06 02:05

一,分类

       一级缓存---session

       二级缓存---sessionFactory

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

 

二,基础知识

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

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

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

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

                        ②调用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.配置

Xml代码 复制代码 收藏代码
  1. <!--开启二级缓存-->  
  2. <property name="hibernate.cache.use_second_level_cache">true</property>  
  3. <property name="cache.provider_class">org.hibernate.cache.OSCacheProvider </property>  
  4.   
  5. <!--hibernate.cfg.xml里配置-->  
  6. <class-cache class="yangzhibin.User" user="read-only "/>  
  7. <!--User.hbm.xml里配置-->  
  8. <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默认查询缓存时关闭 的)

      ① 通过下面方法启动

Xml代码
  1. <!-- 启用查询缓存 -->  
  2. <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来一个一个查询)