mybatis 二级缓存失效_面试题:MyBatis二级缓存

本文详细介绍了MyBatis的一级和二级缓存机制,一级缓存是SqlSession级别,更新操作会导致失效;二级缓存基于mapper的namespace,多个SqlSession可共享,但insert、update、delete会清除缓存。文章指出,虽然二级缓存在面试中常被提及,但在实际工作中因局限性并不常用,分布式环境下更推荐使用Redis等专业缓存服务。
摘要由CSDN通过智能技术生成

一:一级缓存和二级缓存简介

①、一级缓存是SqlSession级别的缓存。在操作数据库时需要构造sqlSession对象,在对象中有一个数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。

②、二级缓存是mapper级别的缓存,多个SqlSession去操作同一个Mapper的sql语句,多个SqlSession可以共用二级缓存,二级缓存是跨SqlSession的。

写这篇文章的初衷:MyBatis二级缓存在实际工作中一般都不会使用,但是就有有些面试官一直问这个问题,所以为了这道面试题,这里专门探讨一下。

二:一级缓存

68c1e24f8bf497a2356ebcbaa1b67bee.png

MyBatis一级缓存也称为查询缓存,是在SqlSession中保存了一个HashMap, key为SQL语句,value为查询出的结果,当一个查询操作会判断查询的语句是否在HashMap中存在,如果存在则直接取出缓存的查询结果,如果不存在就继续查询数据库然后将结果缓存起来。一级缓存又被称为 SqlSession 级别的缓存,会话缓存。一级缓存减少与数据库的交互次数从而降低数据库的压力,进而提高响应速度。MyBatis一级缓存默认是自动开启的,一级缓存是针对于单个SqlSession的,不同的SqlSession之间缓存数据HashMap是无法相互影响的。当insert、update、delete操作时都会清除一级缓存,导致一级缓存失效。

public class SqlSession {      private Map cache = new HashMap();}
org.mybatis.spring.boot    mybatis-spring-boot-starter    2.1.3mysql    mysql-connector-java    runtime
## 数据源配置spring.datasource.url=jdbc:mysql://localhost:3306/test?useUnicode=true&characterEncoding=utf8spring.datasource.username=rootspring.datasource.password=123456spring.datasource.driver-class-name=com.mysql.cj.jdbc.Driver## Mybatis 配置mybatis.typeAliasesPackage=com.example.mybatis.entitymybatis.mapperLocations=classpath:mapper/*.xmlmybatis.configuration.map-underscore-to-camel-case=true# 打印mybatis中的sql语句logging.level.com.example.mybatis.mapper=debug
  • 1
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值