欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页

MyBatis缓存

程序员文章站 2022-06-18 23:30:45
...
MyBatis缓存
介绍:   
      正如大多数持久层框架一样,MyBatis 同样提供了一级缓存和二级缓存的支持。
  1. 一级缓存: 基于PerpetualCache 的 HashMap本地缓存,其存储作用域为 Session,当 Session flush 或 close 之后,该Session中的所有 Cache 就将清空。
  2. 二级缓存与一级缓存其机制相同,默认也是采用 PerpetualCache,HashMap存储,不同在于其存储作用域为 Mapper(Namespace),并且可自定义存储源,如 Ehcache。
  3. 对于缓存数据更新机制,当某一个作用域(一级缓存Session/二级缓存Namespaces)的进行了 C/U/D 操作后,默认该作用域下所有 select 中的缓存将被clear。
一级缓存: 
  1.  MyBatis的一级缓存指的是在一个Session域内,session为关闭的时候执行的查询会根据SQL为key被缓存(跟mysql缓存一样,修改任何参数的值都会导致缓存失效)
  2. 一级缓存是默认开启的,由于我们在使用的过程中会交给spring进行管理session。在进行操作时,spring会自动开启、关闭session。所以在项目有没有使用到一级缓存。
  3. 由于没有使用到,这次就没有对一级缓存进行测试。
二级缓存:
  1. MyBatis的二级缓存需要手动开启。它的作用域是
  2. 在MyBatis配置文件中加入
    <setting name="cacheEnabled" value="true"/> 
  3. 在对应的Mapper.xml中也需要开启
        <cache
            eviction="FIFO"    <!--回收策略为先进先出-->
            flushInterval="60000"   <!--自动刷新时间为60s-->
            size="512"    
            readOnly="true" />
  4.  在对MyBatis的二级缓存测试时,我们需要在查询的时候打印mysql日志。
  5. 首先要保证所需要的jar存在,slf4j-api-1.6.1.jar slf4j-log4j12-1.6.1.jar slf4j-simple-1.6.1.jar 三个jar要保持版本的一致。
  6. 把log的日志级别调到debug,并加入以下配置
    log4j.logger.java.sql.ResultSet=INFO
    log4j.logger.org.apache=INFO
    log4j.logger.java.sql.Connection=DEBUG
    log4j.logger.java.sql.Statement=DEBUG
    log4j.logger.java.sql.PreparedStatement=DEBUG 
  7. 测试查询结果,第一次出现了查询语句,当再次查询时,将不发出查询语句。
     ==>  Preparing: select id, name, pid, url, type,creater,modifier,create_time,modify_time,deleteState from menu where 1=1 and deletestate='0' and pid = '0'  |
     ooo Using Connection [[email protected]] |
     ==> Parameters:  |
     ==>  Preparing: select id, name, pid, url, type,creater,modifier,create_time,modify_time,deleteState from menu where 1=1 and deletestate='0' and pid = '0'  |
     ==> Parameters:  |
     <==      Total: 3 |
     <==      Total: 3 |
总结:
  1. 在使用二级缓存时,需要保证这个namespace中所操作的表不能在其它namespace中进行更新操作。(只有这样才能保持数据的一致性)
  2. 在进行insert、update、delete操作时,会清处当前namespace下的所有缓存。
  3. 如果有两个namespace对同一张表有更新操作,那么就会造成数据的不一致性。