Mybatis的二级缓存问题

一、一级缓存、二级缓存的定义及区别

我们知道mybatis的对JDBC 的一个轻量级的封装,在运行速度方面优于hibernate


一级缓存SqlSession级别的缓存。在操作数据库时需要构造 sqlSession对象,在对象中有一个(内存区域)数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。  一级缓存的作用域是同一个SqlSession,在第一个sqlSession执行相同的sql语句后结果放在内存中,第二次会从缓存中获取数据将不再从数据库查询,从而提高查询效率。当一个sqlSession结束后该sqlSession中的一级缓存也就不存在了。Mybatis默认开启一级缓存。 

本地缓存不能被关闭,可以调用clearCache()清空本地缓存,或者改变缓存的作用域


 二级缓存mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession去操作数据库得到数据会存在二级缓存区域多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。

 二级缓存是多个SqlSession共享的,其作用域是mapper的同一个namespace,第一次执行完毕会将数据库中查询的数据写到缓存(内存),第二次会从缓存中获取数据将不再从数据库查询,从而提高查询效率。

Mybatis默认没有开启二级缓存需要在setting全局参数中配置开启二级缓存。  

如果缓存中有数据就不用从数据库中获取,大大提高系统性能。


二、mybatis的一级二级缓存的使用

我这里采用的是面向接口来操作Mapper.xml文件的

读取SqlSessionFactory工具类:

[java]  view plain  copy
 print ?
  1. package com.itcast.util;  
  2.   
  3. import java.io.IOException;  
  4. import java.io.InputStream;  
  5.   
  6. import org.apache.ibatis.io.Resources;  
  7. import org.apache.ibatis.session.SqlSessionFactory;  
  8. import org.apache.ibatis.session.SqlSessionFactoryBuilder;  
  9.   
  10. public class MyBatisSqlSessionFactiorUtil {  
  11.     public static SqlSessionFactory factory;  
  12.     static{  
  13.         try {  
  14.             String resource = "sqlMapConfig.xml";  
  15.             InputStream inputStream = Resources.getResourceAsStream(resource);  
  16.             factory = new SqlSessionFactoryBuilder().build(inputStream);  
  17.         } catch (IOException e) {  
  18.             e.printStackTrace();  
  19.         }  
  20.           
  21.     }  
  22. }  


一缓缓存:

[java]  view plain  copy
 print ?
  1. /*一级缓存检测*/  
  2.     @Test  
  3.     public void test1(){  
  4.         SqlSession session = factory.openSession();  
  5.         //得到接口  
  6.         UserMapper mapper = session.getMapper(UserMapper.class);  
  7.         Map map = new HashMap();  
  8.         map.put("name""'lijun'");  
  9.         List<User> list = mapper.find(map);  
  10.         for(User user:list){  
  11.             System.out.println(user.toString());  
  12.         }  
  13.         System.out.println("第二次查询直接从缓存汇总拿了,没有发出sql语句:");  
  14.         UserMapper mapper2 = session.getMapper(UserMapper.class);  
  15.         List<User> list2 = mapper2.find(map);  
  16.         for(User user:list2){  
  17.             System.out.println(user.toString());  
  18.         }  
  19.     }  

                 

二级缓存:

mybatis的二级缓存默认是没有开启的,要使用需要开启的。在sqlMapConfig.xml文件中的<configuration>下加上

[html]  view plain  copy
 print ?
  1. <!-- 设置全局二级缓存开启 这个必须放在别名之上,不然会报错误,直接放在第一个 -->  
  2.     <span lang="EN-US" style="font-size: 11pt; font-family: 'Courier New';"><!-- 设置全局二级缓存开启 这个必须放在别名之上,不然会报错误 -->  
  3. <span style="white-space:pre">    </span><settings>  
  4. <span style="white-space:pre">        </span><setting name="cacheEnabled" value="true"/>  
  5. <span style="white-space:pre">    </span></settings></span>  


在Mapper.xml中namespace中使用缓存

[html]  view plain  copy
 print ?
  1. <?xml version="1.0" encoding="UTF-8" ?>  
  2. <!DOCTYPE mapper  
  3. PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN"  
  4. "http://mybatis.org/dtd/mybatis-3-mapper.dtd">  
  5. <!-- 配置命名空间,区别名称 -->  
  6. <mapper namespace="cn.itcast.mapper.PersonMapper">  
  7.     <!-- 使用二级缓存 -->  
  8.     <cache/>  

正常情况下,这样使用就可以了。并且测试也成功:

[html]  view plain  copy
 print ?
  1. /*二级缓存检测,默认情况下,二级缓存是没有开启的,我们需要开启*/  
  2.     @Test  
  3.     public void test2(){  
  4.         SqlSession session = factory.openSession();  
  5.         //得到接口  
  6.         UserMapper mapper = session.getMapper(UserMapper.class);  
  7.         Map map = new HashMap();  
  8.         map.put("name", "'lijun'");  
  9.         List<User> list = mapper.find(map);  
  10.         for(User user:list){  
  11.             System.out.println(user.toString());  
  12.         }  
  13.         session.close();  
  14.         session = factory.openSession();  
  15.         System.out.println("二级缓存:第二次查询直接从缓存汇总拿了,没有发出sql语句:");  
  16.         UserMapper mapper2 = session.getMapper(UserMapper.class);  
  17.         List<User> list2 = mapper2.find(map);  
  18.         for(User user:list2){  
  19.             System.out.println(user.toString());  
  20.         }  
  21.     }  

成功获取二级缓存:

     


上面也是正常情况下,就可以了。但是二级缓存也是可以优化的。二级缓存怎么优化?

在实际开发中,经过在线上压力测试,找到一个符合当前客户运行环境下最恰当的值。
默认mybatis二级缓存一般,可以进行配置

                    


另外还有就是使用第三方的Cache《Ehcache》

第三方cache中有两个佼佼者;可以使用第三方包,包在本例下载页
Ehcache 单机
Momeycache 集群

                     

加入后,再配置一下

<cachetype="org.mybatis.caches.ehcache.EhcacheCache"/>

但是这样测试会报这样的错,说是缺少配置文件,比如:

     


将jar包中的下列配置文件拷入src下,并且更名为ehcache.xml,配置文件内容不需要修改即可


  • 6
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值