Mybatis——生命周期和作用域、缓存

本文详细介绍了Mybatis的生命周期、作用域以及缓存机制。从SqlSessionFactoryBuilder、SqlSessionFactory和SqlSession的作用与生命周期,到Mybatis的一级缓存和二级缓存的工作原理,包括一级缓存的默认开启及失效情况,二级缓存的配置和实现,以及自定义缓存如使用ehcache的设置。缓存的使用能显著减少数据库交互,提高系统效率。
摘要由CSDN通过智能技术生成

Mybatis——生命周期和作用域、缓存

工作流程图

图1569660357745

由上图可知

生命周期作用域,是至关重要的,因为错误的使用会导致非常严重的并发问题

1.SqlSessionFactoryBuilder:

  • 一旦创建了 SqlSessionFactory,就不再需要SqlSessionFactoryBuilder了;
  • 因此SqlSessionFactoryBuilder是局部变量;

2.SqlSessionFactory:

  • 说白了就是可以想象为 :数据库连接池
  • SqlSessionFactory 一旦被创建就应该在应用的运行期间一直存在,没有任何理由丢弃它或重新创建另一个实例。
  • 因此 SqlSessionFactory 的最佳作用域是应用作用域。
  • 最简单的就是使用单例模式或者静态单例模式。

3.SqlSession

  • 连接到连接池的一个请求!
  • SqlSession 的实例不是线程安全的,因此是不能被共享的,所以它的最佳的作用域是请求或方法作用域。
  • 用完之后需要赶紧关闭,否则资源被占用!

如图所示

图1569660737088

这里面的每一个Mapper,就代表一个具体的业务!

4.Mybatis详细的执行流程!

图Temp

5.缓存

5.1、简介

提出缓存的原因:

因为查询需要连接数据库 ,这导致十分耗资源!

假设,一次查询的结果,把它暂存在一个可以直接取到的地方(内存 : 缓存)!

我们再次查询相同数据的时候,直接走缓存,就不用走数据库了

  1. 什么是缓存 [ Cache ]?

    • 存在内存中的临时数据。
    • 将用户经常查询的数据放在缓存(内存)中,用户去查询数据就不用从磁盘上(关系型数据库数据文件)查询,从缓存中查询,从而提高查询效率,解决了高并发系统的性能问题。
  2. 为什么使用缓存?

    • 减少和数据库的交互次数,减少系统开销,提高系统效率。
  3. 什么样的数据能使用缓存?

    • 经常查询并且不经常改变的数据。【可以使用缓存】

    • 不经常查询并且经常改变的数据就不适合使用缓存。

5.2、Mybatis缓存
  • MyBatis包含一个非常强大的查询缓存特性,它可以非常方便地定制和配置缓存。缓存可以极大的提升查询效率。
  • MyBatis系统中默认定义了两级缓存:一级缓存二级缓存
    • 默认情况下,只有一级缓存开启。(SqlSession级别的缓存,也称为本地缓存)

    • 二级缓存需要手动开启和配置,它是基于namespace级别的缓存。

    • 为了提高扩展性,MyBatis定义了缓存接口Cache。我们可以通过实现Cache接口来自定义二级缓存

5.3、一级缓存

一级缓存也叫本地缓存: SqlSession

  • 与数据库第一次会话期间查询到的数据会放在本地缓存中。
  • 以后如果需要获取相同的数据,直接从缓存中拿,没必须再去查询数据库;

测试步骤:

  1. 开启日志!
  2. 测试在一个Sesion中查询两次相同记录
  3. 查看日志输出

图51=================

缓存失效的情况:

  1. 查询不同的东西

  2. 增删改操作,可能会改变原来的数据,所以必定会刷新缓存!

图58======================

3.查询不同的Mapp

  • 1
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Mybatis提供了两级缓存: - 一级缓存(本地缓存):Mybatis默认开启的,其作用域为SqlSession级别,即在同一个SqlSession执行相同的查询语句,第一次查询结果会被缓存下来,再次查询相同语句时直接从缓存获取结果,避免了重复查询数据库,提高了效率。 - 二级缓存(全局缓存):其作用域为整个应用程序,多个SqlSession之间可以共享缓存数据,需要手动开启。当SqlSession执行查询时,查询的数据会被缓存二级缓存,再次执行相同的查询时,直接从缓存获取数据,避免了重复查询数据库,提高了效率。 二级缓存需要注意以下几点: - 对于同一条SQL语句,如果执行过程有任何的update、insert、delete操作,那么缓存会被清空,下次查询会重新执行SQL语句并缓存结果。 - 对于同一条SQL语句,如果有多个参数,那么不同参数对应的查询结果也会被缓存到不同的缓存,需要注意查询参数的一致性。 - 二级缓存存储的是对象的引用地址,而不是对象本身,因此需要保证缓存的对象不被修改。 一级缓存二级缓存的区别: - 一级缓存是SqlSession级别的缓存生命周期比较短,只在SqlSession内有效,而二级缓存是全局的缓存生命周期比较长,多个SqlSession可以共享缓存数据。 - 一级缓存默认开启,二级缓存需要手动开启。 - 一级缓存是基于对象引用的缓存,与数据库同步,而二级缓存是基于数据的缓存,与数据库异步。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值