博客
关于我
MyBatis:6、MyBatis缓存
阅读量:303 次
发布时间:2019-03-04

本文共 2812 字,大约阅读时间需要 9 分钟。

MyBatis 缓存

  • 什么是 MyBatis 缓存:

    使用缓存可以减少 Java 引用与数据库的交互次数,从而提升程序的运行效率。比如查询出 id = 1 的对象,第一次查询出之后会自动将该对象保存到缓存中,当下一次查询时,直接从缓存中取出对象即可,无需再次访问数据库。

  • MyBatis 缓存分类

    1、一级缓存:SqlSession 级别,默认开启,并且不能关闭。

    操作数据库时需要创建 SqlSession 对象,在对象中有一个 HashMap 用于存储缓存数据,不同的 SqlSession 之间缓存数据区域是互不影响的。

    一级缓存的作用域是 SqlSession 范围的,当在同一个 SqlSession 中执行两次相同的 SQL 语句时,第一次执行完毕会将结果保存到缓存中,第二次查询时直接从缓存中获取。

    需要注意的是,如果 SqlSession 执行了 DML 操作(insert、update、delete),MyBatis 必须将缓存清空,以保证数据的准确性。

    2、二级缓存:Mapper 级别,默认关闭,可以开启。

    使用二级缓存时,多个 SqlSession 使用同一个 Mapper 的 SQL 语句操作数据库,得到的数据会存在二级缓存区,同样是使用 HashMap 进行数据存储,相比较与一级缓存,二级缓存的范围更大,多个 SqlSession 可以共用二级缓存,二级缓存是跨 SqlSession。

    二级缓存是多个 SqlSession 共享的,其作用域是 Mapper 的同一个 namespace,不同的 SqlSession 两次执行相同的 namespace 下的 SQL 语句,参数也相等,则第一次执行成功之后会将数据保存到二级缓存中,第二次可直接从二级缓存中取出数据。

    代码:

    ① 一级缓存

    package com.xiaoxin.test;import com.xiaoxin.entity.Account;import com.xiaoxin.repository.AccountRepository;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 java.io.IOException;import java.io.InputStream;public class test7 {
    public static void main(String[] args) throws IOException {
    InputStream inputStream = Resources.getResourceAsStream("config.xml"); SqlSessionFactoryBuilder builder = new SqlSessionFactoryBuilder(); SqlSessionFactory factory = builder.build(inputStream); SqlSession sqlSession = factory.openSession(); AccountRepository accountRepository = sqlSession.getMapper(AccountRepository.class); AccountRepository accountRepository1 = sqlSession.getMapper(AccountRepository.class); Account account = accountRepository.findById(1L); Account account1 = accountRepository1.findById(1L); System.out.println(account); System.out.println(account1); sqlSession.close(); }}

    输出发现,执行了一次 sql 语句:

    在这里插入图片描述

② 二级缓存:

1、MyBatis 自带的二级缓存

  • config.xml 中只配置开启二级缓存

  • Mapper.xml 中配置二级缓存

  • 实体类实现序列化接口

    package com.xiaoxin.entity;import lombok.AllArgsConstructor;import lombok.Data;import lombok.NoArgsConstructor;import java.io.Serializable;@Data@NoArgsConstructor@AllArgsConstructorpublic class Account implements Serializable {
    private long id; private String username; private String password; private int age;}

2、使用第三方的二级缓存,mybatis-ehcache

  • pom.xml 中添加相关依赖

    org.mybatis
    mybatis-ehcache
    1.0.0
  • 添加 ehcache 配置文件

  • 在 config.xml 中配置开启二级缓存:

  • Mapper.xml中配置二级缓存

  • 实体类不需要实现序列化接口

转载地址:http://ldjq.baihongyu.com/

你可能感兴趣的文章
jQuery练习t310,从0到1
查看>>
asp.net 4.5 练习~test15-1 xml文件使用xslt转换格式
查看>>
asp.net代码练习 work015 回调技术
查看>>
asp.net代码练习 work016 fileupload文件上传
查看>>
asp.net代码练习 work021 DataReader的使用
查看>>
PHP7.0--如何使用函数的引用
查看>>
Java基础--01--数据类型/方法/数组
查看>>
【JokerのZYNQ7020】LINUX_EMIO_LED。
查看>>
【JokerのZYNQ7020】LINUX_EMIO_BUTTON。
查看>>
将代码从windows移动linux上出现^M错误的解决方法
查看>>
git查看相对于最新的push改动内容
查看>>
vim匹配特定的行并删除
查看>>
读取excel文件错误
查看>>
傅里叶变换的初级理解三
查看>>
伟大的欧拉公式
查看>>
F1 score的意义
查看>>
画多个图及相关细节总结
查看>>
python36+centos7离线安装tensorflow与talib的方法
查看>>
金融数据信噪比的影响力又一力证
查看>>
hdf5与hdfs的区别
查看>>