MyBatis 的一级缓存和二级缓存的区别

简介: MyBatis 的一级缓存和二级缓存的区别

MyBatis 的一级缓存和二级缓存有以下几个主要区别:

  1. 作用范围:

·        一级缓存是在同一个 SqlSession 中有效的,即在同一个数据库连接会话中。一级缓存是在同一个 SqlSession 中有效的,即在同一个数据库连接会话中。在同一个 SqlSession 中执行相同的查询操作,若命中一级缓存,则会直接返回缓存中的结果对象,而不再发送对数据库的实际查询请求。一级缓存的粒度较细,作用在单个 SqlSession 内部,多个相同的查询操作可以共享缓存结果。

·        二级缓存是跨 SqlSession 的,可以实现多个 SqlSession 之间的缓存共享,具体的作用范围是 Mapper 接口级别的。不同的 Mapper 接口拥有独立的缓存空间,相同的查询操作结果可以被多个 SqlSession 共享。跨多个 SqlSession 的查询操作,若命中二级缓存,则会从缓存获取结果对象,而不再发送对数据库的实际查询请求。二级缓存的粒度较粗,作用在整个 Mapper 接口,多个 SqlSession 可以共同使用并共享缓存结果。

  1. 生命周期:
  • 一级缓存的生命周期是与 SqlSession 相关的。当一个 SqlSession 结束(包括提交事务或关闭 SqlSession)后,一级缓存也会失效,其缓存的结果对象将被释放。
  • 二级缓存的生命周期是比较长久的,它在多个 SqlSession 之间进行缓存共享。一般来说,在整个 MyBatis 应用程序的生命周期内,二级缓存都可以保持有效,直到显式地刷新或清空缓存。
  1. 存储方式:
  • 一级缓存存储的是查询操作的结果对象,而不是数据表中的实际数据。它位于内存中,属于临时的缓存。
  • 二级缓存也存储的是查询操作的结果对象,它的存储位置可以是内存、磁盘等,具体取决于缓存实现的策略。它是持久化的缓存,可以在不同的 SqlSession 之间进行共享。
  1. 缓存粒度:
  • 一级缓存的粒度较细,是基于 SqlSession 的。相同的查询操作会直接使用缓存结果,减少了与数据库的交互。
  • 二级缓存的粒度较粗,是基于 Mapper 接口的。不同的 Mapper 接口拥有独立的缓存空间。相同的查询操作结果可以被多个 SqlSession 共享,减少了数据库的查询压力。

需要根据具体的业务场景和需求合理选择使用一级缓存还是二级缓存,或者两者一起使用,以达到最佳的性能和缓存效果。同时,也需要注意缓存带来的数据一致性和实时性问题,避免脏数据的读取或缓存滞后的情况。需要注意的是二级缓存默认是关闭的,如果想详细了解一级缓存或者是二级缓存可查看博主的另外详解的帖子。

 

相关文章
|
1月前
|
存储 缓存 芯片
让星星⭐月亮告诉你,当我们在说CPU一级缓存二级缓存三级缓存的时候,我们到底在说什么?
本文介绍了CPU缓存的基本概念和作用,以及不同级别的缓存(L1、L2、L3)的特点和工作原理。CPU缓存是CPU内部的存储器,用于存储RAM中的数据和指令副本,以提高数据访问速度,减少CPU与RAM之间的速度差异。L1缓存位于处理器内部,速度最快;L2缓存容量更大,但速度稍慢;L3缓存容量最大,由所有CPU内核共享。文章还对比了DRAM和SRAM两种内存类型,解释了它们在计算机系统中的应用。
74 1
|
2月前
|
缓存 Java 数据库连接
mybatis复习05,mybatis的缓存机制(一级缓存和二级缓存及第三方缓存)
文章介绍了MyBatis的缓存机制,包括一级缓存和二级缓存的配置和使用,以及如何整合第三方缓存EHCache。详细解释了一级缓存的生命周期、二级缓存的开启条件和配置属性,以及如何通过ehcache.xml配置文件和logback.xml日志配置文件来实现EHCache的整合。
mybatis复习05,mybatis的缓存机制(一级缓存和二级缓存及第三方缓存)
|
13天前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
13天前
|
SQL 缓存 Java
MyBatis如何关闭一级缓存(分注解和xml两种方式)
MyBatis如何关闭一级缓存(分注解和xml两种方式)
42 5
|
18天前
|
SQL 安全 Java
MyBatis(6)#{}和${}的区别
在MyBatis中,`#{}`和`${}`是用于在SQL语句中嵌入参数的两种方式。`#{}`用于预处理参数,可以防止SQL注入;而`${}`进行直接字符串替换,适用于动态插入表名或列名,但存在SQL注入风险。建议优先使用`#{}`,并在必要时谨慎使用`${}`。
|
29天前
|
缓存 Java 数据库连接
使用MyBatis缓存的简单案例
MyBatis 是一种流行的持久层框架,支持自定义 SQL 执行、映射及复杂查询。本文介绍了如何在 Spring Boot 项目中集成 MyBatis 并实现一级和二级缓存,以提高查询性能,减少数据库访问。通过具体的电商系统案例,详细讲解了项目搭建、缓存配置、实体类创建、Mapper 编写、Service 层实现及缓存测试等步骤。
|
2月前
|
SQL XML Java
mybatis复习02,简单的增删改查,@Param注解多个参数,resultType与resultMap的区别,#{}预编译参数
文章介绍了MyBatis的简单增删改查操作,包括创建数据表、实体类、配置文件、Mapper接口及其XML文件,并解释了`#{}`预编译参数和`@Param`注解的使用。同时,还涵盖了resultType与resultMap的区别,并提供了完整的代码实例和测试用例。
mybatis复习02,简单的增删改查,@Param注解多个参数,resultType与resultMap的区别,#{}预编译参数
|
4月前
|
缓存 算法 Java
关于MyBatis的缓存详解
MyBatis 的缓存机制非常灵活,可以通过简单的配置来满足不同的性能需求。合理地使用缓存可以显著提高应用程序的性能,尤其是在处理大量数据库查询时。然而,开发者需要注意缓存的一致性和并发问题,特别是在使用可读写缓存时。
|
3月前
|
SQL Java 数据库连接
MyBatis 和 Hibernate 有什么区别?
【8月更文挑战第21天】
65 0
|
3月前
|
存储 缓存 Java