经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » Java相关 » Java » 查看文章
Mybait缓存机制(四)
来源:cnblogs  作者:Miya。  时间:2018/10/16 9:40:32  对本文有异议

MyBatis同大多数ORM框架一样,提供了一级缓存和二级缓存的支持。

一级缓存:其作用域为session范围内,当session执行flush或close方法后,一级缓存会被清空。

二级缓存:二级缓存和一级缓存机制相同,但是可以自定义其作用范围,如Ehcache。

一级缓存

在默认情况下mybatis中的一级缓存是开启的,一级缓存只在同一个SqlSession中有效不可以跨SqlSession。

  1. @Test
  2. public void testcache(){
  3. /**
  4. * 测试一级缓存
  5. */
  6. SqlSession session1 = sqlSessionFactory.openSession();
  7. EmployeeMapper employeeMapper = session1.getMapper(EmployeeMapper.class);
  8. List<Employee> list1 = employeeMapper.findAll(null);
  9. System.out.println(list1);
  10. List<Employee> list2 = employeeMapper.findAll(null);//不发送语句
  11. System.out.println(list2);
  12. }

SqlSession调用clearCache()清除缓存,或者在执行增删改操作后,SqlSession调用close(),commit()都会清理缓存。

二级缓存

MyBatis中使用二级缓存也非常简单,首先开启全局二级缓存配置信息,通过开启cacheEnabled,然后在对应的mapper映射文件中使用<cache />标签开启二级缓存即可。

1.select 语句获取出来的对象都会被缓存。

2.二级缓存所有实体类必须实现Serializable接口。

3.所有执行 insert,update 和 delete 语句后,缓存都会被刷新。
4.必须关闭session后才会写入二级缓存中。

5.二级缓存的作用域是全局的,作用范围是映射文件级别的。只在同一类型mapper映射对象中有效。

6.查询数据时,会先查询二级缓存,再查询一级缓存,然后再查询数据库。

我们需要使用二级缓存必须在mybatis主配置文件中设置cacheEnabled设置为true,并且在实体类Mapper中启用缓存。

  1. <settings>
  2. <!-- 开启驼峰式命名规则 -->
  3. <setting name="mapUnderscoreToCamelCase" value="true"/>
  4. <!-- 开启二级缓存 -->
  5. <setting name="cacheEnabled" value="true"/>
  6. </settings>

EmployeeMapper.xml

  1. <!-- 使用mybatis默认二级缓存 -->
  2. <cache/>

这样就可以开启我们的二级缓存了,但是这使用至少mybatis默认的二级缓存,mybatis缓存做的并怎么的好,所有我们需要整合第三方缓存机制。

EhCache 是一个纯Java的进程内缓存框架,是一种广泛使用的开源Java分布式缓存,具有快速、精干等特点,是Hibernate中默认的二级缓存。所以我们来整合Ehcache

导入:mybatis-ehcache-1.0.3.jar ,ehcache-core-2.6.8.jar,slf4j-api-1.7.25.jar ,slf4j-log4j12-1.7.25.jar

这个时候我们只需要在实体类指定只用EhCache缓存即可

  1. <!-- 使用第三方缓存 -->
  2. <cache type="org.mybatis.caches.ehcache.EhcacheCache" />

我们可以创建ehcache.xml配置文件也可以直接配置

  1. <cache type="org.mybatis.caches.ehcache.EhcacheCache"/>
  2. <property name="timeToIdleSeconds" value="3600"/><!--1 hour-->
  3. <property name="timeToLiveSeconds" value="3600"/><!--1 hour-->
  4. <property name="maxEntriesLocalHeap" value="1000"/>
  5. <property name="maxEntriesLocalDisk" value="10000000"/>
  6. <property name="memoryStoreEvictionPolicy" value="LRU"/>
  7. </cache>

二级缓存属性

  1. <cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>

和缓存相关的设置

1.核心配置文件中的cacheEnabled=true|false,开启或关闭缓存(默认为true),只对二级缓存有效,对一级缓存无效。
2.在select标签中有一个属性useCache=true|false,开启当前查询标签的缓存(默认为true),也是只对二级缓存有效,对一级缓存无效。
3.在每个增删改标签中都有一个flushCache=true|false属性,设置是否清除缓存(默认为true)。一级和二级缓存都会被清空。
4.在查询中也有flushCache=true|false 属性(默认为false),如果设置为true,则每次查询之后都会清除缓存。
5.sqlsession.clearCache()方法,清除缓存。只能清除一级缓存,对二级缓存无效。
6.全局配置文件中的localCacheScope属性,表示本地缓存作用域(一级缓存)。取值为session|statement。默认为session。如果设置为statement,一级缓存会被禁用掉。

 

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号