MyBatis一级和二级缓存介绍

作者 : admin 本文共1234个字,预计阅读时间需要4分钟 发布时间: 2024-06-8 共6人阅读

MyBatis是一个持久层框架,它提供了一级缓存和二级缓存来提高数据库操作的性能。下面是一级缓存和二级缓存的区别理解、画图和知识点总结:

一级缓存:

  • 一级缓存是MyBatis默认开启的缓存层,它是SqlSession级别的缓存,也就是说同一个SqlSession中的多次查询会使用同一个缓存。
  • 一级缓存是在内存中实现的,它的生命周期与SqlSession相同。
  • 当SqlSession执行查询时,查询的结果会被保存在一级缓存中,下次再执行相同的查询语句时,会直接从缓存中取结果,而不需要再次访问数据库。
  • 一级缓存的失效条件包括:SqlSession关闭、手动清除缓存、增删改操作等。
  • 一级缓存的范围是SqlSession级别的,不同的SqlSession之间无法共享缓存。

二级缓存:

  • 二级缓存是MyBatis中的全局缓存,它是mapper级别的缓存,多个SqlSession可以共享同一个二级缓存。
  • 二级缓存是在SqlSessionFactory的级别实现的,它的生命周期与应用程序的生命周期相同。
  • 当SqlSession执行查询时,查询的结果会被保存在二级缓存中,下次再执行相同的查询语句时,会直接从缓存中取结果,而不需要再次访问数据库。
  • 二级缓存的失效条件包括:SqlSessionFactory刷新、手动清除缓存、增删改操作等。
  • 二级缓存的范围是mapper级别的,同一个namespace下的mapper可以共享二级缓存,不同的namespace之间无法共享缓存。
  • 使用二级缓存需要在Mapper的配置文件中配置标签。

总结:

  • 一级缓存是SqlSession级别的缓存,二级缓存是mapper级别的缓存。
  • 一级缓存的生命周期是与SqlSession相同,二级缓存的生命周期是与应用程序相同。
  • 一级缓存的范围是SqlSession级别的,二级缓存的范围是mapper级别的。
  • 一级缓存的作用范围是在同一个SqlSession中,二级缓存的作用范围是在多个SqlSession中。
  • 一级缓存是默认开启的,而使用二级缓存需要在Mapper的配置文件中进行配置。

以下是一级缓存和二级缓存的简单示意图:

+------------+                  +----------------+
| SqlSession | ---------------->|       DB       |
|            |                  |                |
+----^-------+                  +------+---------+
     |                                   |
     |                                   |
     |                                   |
     |         +-----------------+       |
     +-------> |   一级缓存      | <-----+
               +-----------------+

+-----------------------+           +----------------+
|   SqlSessionFactory   |           |       DB       |
|                       |           |                |
+----^--------------+---+           +------+---------+
     |                                     |
     |                                     |
     |                                     |
     |        +-----------------+          |
     +------> |   二级缓存      | <--------+
               +-----------------+

本站无任何商业行为
个人在线分享 » MyBatis一级和二级缓存介绍
E-->