与Hibernate一样,MyBatis 也提供了一级缓存和二级缓存的支持。

1、一级缓存:(本地缓存)SqlSession级别的缓存,默认一直开启的 ,

与数据库同一次会话期间的数据会放到本地缓存中,以后如果需要相同的数据,直接从缓存中拿,不再查询数据库。

当 Session flush 或 close 之后,该Session中的所有 Cache 就将清空。

    当进行增删改之后,该Session中的所有 Cache 就将清空。

2、二级缓存:基于namespace级别的缓存,一个namespace对应一个二级缓存

    可自定义存储源,如 Ehcache。

    当 Session flush 或 close 之后,二级缓存仍然可用。

    当进行增删改之后,该namespace的所有 Cache 就将清空。

    <setting name="cacheEnabled" value="false" />可关闭二级缓存,一级缓存可用。

一、一级缓存

package com.pjf.mybatis;

import java.io.IOException;
import java.io.InputStream;import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test; import com.pjf.mybatis.dao.HotelMapper;
import com.pjf.mybatis.po.Hotel; public class TestHotel { public SqlSessionFactory sqlSessionFactory() throws IOException {
String resource = "mybatis_config.xml";
InputStream is = Resources.getResourceAsStream(resource);
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);
return sessionFactory;
}
/*
* Mybatis缓存机制
* 一级缓存:(本地缓存)SqlSession级别的缓存,默认一直开启的
* 与数据库同一次会话期间的数据会放到本地缓存中
* 以后如果需要相同的数据,直接从缓存中拿,不再查询数据库
* 一级缓存的失效情况(需要重新发送sql)
* 1、sqlSession不同
* 2、sqlSession相同,查询条件不同
* 3、sqlSession相同,查询条件相同,但两次查询之间执行了增删改操作
* 4、sqlSession相同,查询条件相同,手动清除了缓存clearCache()
*/ @Test
public void testMybatisCache() throws IOException { SqlSessionFactory sessionFactory = sqlSessionFactory();
SqlSession session = sessionFactory.openSession(true);
HotelMapper hotelMapper = session.getMapper(HotelMapper.class);
Hotel hotel = hotelMapper.getHotel(1001);
System.out.println(hotel);
//第二次查询,条件一致
Hotel hotel2 = hotelMapper.getHotel(1001);
System.out.println(hotel2);
session.close();
}
}

一级缓存在以下四种情况下会失效

1、sqlSession不同
2、sqlSession相同,查询条件不同
3、sqlSession相同,查询条件相同,但两次查询之间执行了增删改操作
4、sqlSession相同,查询条件相同,手动清除了缓存clearCache()

二、二级缓存

修改HotalMapper.xml文件

<?xml version="1.0" encoding="UTF-8" ?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0//EN" "http://mybatis.org/dtd/mybatis-3-mapper.dtd" >
<mapper namespace="com.pjf.mybatis.dao.HotelMapper">
<!-- cache 缓存开启
eviction 缓存回售策略
LRU 最近最少使用的,移除最长时间不被使用的(默认)
FIFO 先进先出
SOFT 软引用
WEAK 弱引用
flushInterval 缓存刷新间隔
缓存清空时间,默认不清空,设置毫秒值
readOnly 缓存是否只读
true mybatis只从缓存中毒数据,不会修改数据
false mybatis认为缓存中的数据会被修改,会用序列化和反序列化技术克隆一份给用户,安全,速度慢
size 缓存存放多少元素
type 指定自定义缓存的全类名
-->
<cache eviction="LRU" flushInterval="60000" readOnly="false" size="1024" ></cache> <resultMap type="com.pjf.mybatis.po.Hotel" id="myHotel">
<id column="id" property="id" jdbcType="INTEGER" />
<result column="hotel_name" property="hotelName" jdbcType="VARCHAR" />
<result column="hotel_address" property="hotelAddress"jdbcType="VARCHAR" />
<result column="price" property="price" jdbcType="INTEGER" />
</resultMap> <select id="getHotel" resultMap="myHotel">
select*
from hotel where id =#{id}
</select>
</mapper>

测试类

package com.pjf.mybatis;

import java.io.IOException;
import java.io.InputStream;import org.apache.ibatis.io.Resources;
import org.apache.ibatis.session.SqlSession;
import org.apache.ibatis.session.SqlSessionFactory;
import org.apache.ibatis.session.SqlSessionFactoryBuilder;
import org.junit.Test; import com.pjf.mybatis.dao.HotelMapper;
import com.pjf.mybatis.po.Hotel; public class TestHotel { public SqlSessionFactory sqlSessionFactory() throws IOException {
String resource = "mybatis_config.xml";
InputStream is = Resources.getResourceAsStream(resource);
SqlSessionFactory sessionFactory = new SqlSessionFactoryBuilder().build(is);
return sessionFactory;
}
/*
* 二级缓存:基于namespace级别的缓存,一个namespace对应一个二级缓存
* 工作机制:
* 1、一个会话查询一个数据,这个数据会被保存到当前会话的一级缓存中
* 2、如果会话关闭,一级缓存中的数据会被保存到二级缓存中,新的会话消息,就可以查询二级缓存
* 3、不同namespace查出来的数据,会被放在自己对应的缓存中
* 使用:
* 1、开启全局二级缓存配置 <setting name="cacheEnabled" value="true" />
* 2、去mapper.xml配置使用二级缓存 <cache></cache>
* 3、pojo需要实现序列化接口
*/
@Test
public void testMybatisCache() throws IOException { SqlSessionFactory sessionFactory = sqlSessionFactory();
SqlSession session = sessionFactory.openSession(true);
HotelMapper hotelMapper = session.getMapper(HotelMapper.class);
Hotel hotel = hotelMapper.getHotel(1001);
System.out.println(hotel);
//关闭第一次会话
session.close();
//第二次查询
SqlSession session2 = sessionFactory.openSession(true);
HotelMapper hotelMapper2 =session2.getMapper(HotelMapper.class);
Hotel hotel2 = hotelMapper2.getHotel(1001);
System.out.println(hotel2);
session2.close();
}
}

二级缓存使用的时候主要有三步:

1、开启全局二级缓存配置   <setting name="cacheEnabled" value="true" />
2、去mapper.xml配置使用二级缓存 <cache></cache>
3、pojo需要实现序列化接口

mybatis学习(十)——缓存介绍的更多相关文章

  1. MyBatis学习--查询缓存

    简介 以前在使用Hibernate的时候知道其有一级缓存和二级缓存,限制ORM框架的发展都是互相吸收其他框架的优点,在Hibernate中也有一级缓存和二级缓存,用于减轻数据压力,提高数据库性能. m ...

  2. mybatis学习 十一 缓存

    1. 应用程序和数据库交互的过程是一个相对比较耗时的过程2. 缓存存在的意义:让应用程序减少对数据库的访问,提升程序运行效率3. MyBatis 中默认 SqlSession 缓存(一级缓存)开启 同 ...

  3. Mybatis学习笔记-缓存

    简介 什么是缓存 **将一次查询的结果暂存至内存,后续查询只需查询缓存** 为什么使用缓存 **减少与数据库的交互次数,减少系统开销,提高系统效率** 什么样的数据能使用缓存 **经常查询且不常修改的 ...

  4. mybatis学习 十二 多表查询

    Mybatis 实现多表查询方式: (1)业务装配.对两个表编写单表查询语句,在业务(Service)把查询的两个结果进行关联. (2)使用Auto Mapping特性,在实现两表联合查询时通过别名完 ...

  5. mybatis学习 十 动态 SQL

    1.  根据方法传入的参数不同执行不同的 SQL 命令.称为动态 SQL, MyBatis 中动态 SQL 就是在 mapper.xml 中添加逻辑判断等. 2. <if>标签 <s ...

  6. mybatis学习 十六 auto_mapping实现连表查询

    只能使用多表联合查询方式. 要求:查询出的列别和属性名相同. 点字符  "."  在 SQL 是关键字符,两侧添加反单引号(Tab键上的一个字符) <select id=&q ...

  7. mybatis学习 十五 resultMap标签 一对多

    多次查询,非联合查询版本 <resultMap type="teacher" id="techMap"> <id column="i ...

  8. mybatis学习 十四 resultMap标签 一对一(联合查询)

    1.使用 resultMap 实现关联单个对象(联合查询方式) <resultMap type="Student" id="stuMap1"> &l ...

  9. Mybatis学习笔记导航

    Mybatis小白快速入门 简介 本人是一个Java学习者,最近才开始在博客园上分享自己的学习经验,同时帮助那些想要学习的uu们,相关学习视频在小破站的狂神说,狂神真的是我学习到现在觉得最GAN的老师 ...

随机推荐

  1. CF Gym 100187B A Lot of Joy (古典概型)

    题意:给两个一样的只含有26个小写字母的字符串,然后两个分别做一下排列,问如果对应位置的字母相等那么就愉悦值就加一,问愉悦值的期望是多少? 题解:只考虑两个序列相对的位置,那么就相当于固定一个位置,另 ...

  2. Mycat实现读写分离、分库分表

    系统开发中,数据库是非常重要的一个点.除了程序的本身的优化,如:SQL语句优化.代码优化,数据库的处理本身优化也是非常重要的.主从.热备.分表分库等都是系统发展迟早会遇到的技术问题问题.Mycat是一 ...

  3. 在DataGridView控件中验证数据输入

    实现效果: 知识运用: DataGridView控件的公共事件CellValidating //将System.Windows.Forms.DataGridViewCellValidatingEven ...

  4. oracle 数据导到 sql server

    方法一: navicate:用法比较简单,选择工具-数据传输就可以了.目前测试了下暂时没遇到什么问题. 方法二: Microsoft SQL Server Migration Assistant 8. ...

  5. 用户价值模型 CITE :https://www.jianshu.com/p/34199b13ffbc

    RFM用户价值模型的原理和应用  ▌定义 在众多的用户价值分析模型中,RFM模型是被广泛被应用的:RFM模型是衡量客户价值和客户创利能力的重要工具和手段,在RFM模式中,R(Recency)表示客户购 ...

  6. Java中 Character方法练习:字符串中英文字母个数 5435abc54abc3AHJ5 正则:matches("[a-zA-Z0-9]{1}")

    package com.swift; public class String_Letter_Number_Test { public static void main(String[] args) { ...

  7. [BZOJ] 1907: 树的路径覆盖

    一个点必然被路径覆盖,根据是否为路径的端点分类 \(f[x][0]\)表示以\(x\)为根的子树,\(x\)不为端点的最小路径覆盖数 \(f[x][1]\)表示以\(x\)为根的子树,\(x\)为一条 ...

  8. 解决mysql出现的问题#1055 - Expression of SELECT list is not in GROUP BY clause and contains nonaggregated column this i

    最近在学flask, 在访问主页时,一直出现1055错误,在网上找的解决方法是删除ONLY_FULL_GROUP_BY,当时是删除了,但是退出在进行select @@sql_mode时,仍出现ONLY ...

  9. Python爬虫系列-Selenium详解

    自动化测试工具,支持多种浏览器.爬虫中主要用来解决JavaScript渲染的问题. 用法讲解 模拟百度搜索网站过程: from selenium import webdriver from selen ...

  10. JAVA基础篇—抽象类,抽象方法

    class Shape package com.shape; public abstract class Shape { double area;// double per;// String col ...