本文共 2812 字,大约阅读时间需要 9 分钟。
什么是 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/