MyBatis 缓存一--实训2019/10/28

1、Mybatis简单配置介绍,基于XML的配置

(1)配置步骤

简单来说,Mybatis的配置主要分为以下几步(整合Spring之后有些就不需要了,但是一开始学习不建议直接整合Spring):

  • 编写POJO即JavaBean,最终的目的是将数据库中的查询结果映射到JavaBean上;
  • 配置与POJO对应的Mapper接口:里面有各种方法,对应mapper.xml中的查询语句;
  • 配置与POJO对应的XML映射:编写缓存,SQL查询等;
  • 配置mybatis-config.xml主要的Mybatis配置文件:配置数据源、扫描mapper.xml等。
      注意:以上的配置并没有严格的前后顺序;

MyBatis 缓存一--实训2019/10/28

2、Mybatis生命周期

mybatis-config.xml
------->SqlSessionFactoryBuilder(创建一个构建器,一旦创建了SqlSessionFactory,它的任务就算完成了,可以回收)
-------->SqlSessionFacotry 相当于JDBC的一个Connection对象,每次应用程序需要访问数据库,我们就要通过SqlSessionFactory创建一个SqlSession
-------->SqlSession 请求数据库处理事务的过程中
-------->mapper;是一个接口,发送SQL 或返回结果,存活于一个SqlSession内

备注:

  1. 所以SqlSessionFactory在整Mybatis整个生命周期中(每个数据库对应一个SqlSessionFactory,是单例产生的)
  2. SqlSession是一个线程不安全的对象(在多线程的情况下,需要特别注意),即存活于一个应用的请求和申请,可以执行多条SQL保证事务的一致性。
  3. 当SqlSession销毁的时候,Mapper也会销毁。

3、Myabtis缓存介绍

(1)系统缓存:包括一级缓存与二级缓存

一级缓存:默认情况下Myabtis对于同一个SqlSession开启一级缓存

  • 在默认没有配置的情况下,只会开启一级缓存(只针对同一个SqlSession而言);
  • 在参数与SQL完全一样的情况下并且不声明刷新缓存没超时的,使用同一个SqlSession对象调用同一个Mapper方法时(SqlSession对象生命周期为方法级别),SqlSession只会取出当前缓存数据,不会再到数据库中进行查询;
  • 如果不同的SqlSession,即使同一个Mapper也会进行到数据库中进行不同的查询,即不同的SqlSession一级缓存是无效的。

二级缓存:这里可以结合SqlSessionFactory等的生命周期能加深理解

  • 不同的SqlSession是隔离的,为了解决这个问题,我们可以在SqlSessionFactory层面上设置二级缓存提供各个对象SqlSession
  • 二级缓存默认是不开启的,需要进行配置,Mybatis要求返回的POJO必须是可序列化的,即POJO实现Serializable接口。
      缓存的配置只需要在XML配置即可,或者指定算法,刷新时间间隔,缓存状态,大小等

< cache eviction=“LRU” readOnly=“true” flushInterval=“100000” size=“1024”>< /cache>

A. 映射语句文件中所有select语句将会被缓存;

B. 映射语句文件中所有insert、update和delete语句会被刷新缓存;

C. 缓存使用默认的LRU最近最少使用算法回收;

D. 根据时间表,缓存不会任何时间顺序刷新;

E. 缓存会存储列表集合或对象的1024个引用

F. 缓存被视为可read/write的缓存,意味着是不可以被共享的,而可以被安全地修改。
(2)自定义缓存:结合Redis等主流缓存配置

我们可以使用比如现在比较火的Redis缓存,需要实现Myabtis为我们提供的接口org.apache.ibatis.cache.Cache。虽然现在主流Mybatis用的都是自定义缓存,