【SSM】MyBatis(十二.缓存)

文章目录

  • 1.MyBatis缓存作用
  • 2.一级缓存
    • 2.1 原理
    • 2.2 什么时候不走缓存
    • 2.3 一级缓存失效
  • 3.二级缓存
    • 3.1 原理
    • 3.2 二级缓存的失效
    • 3.3 二级缓存相关配置

1.MyBatis缓存作用

将select语句的查询结果放到缓存(内存)当中,下一次还是这条select语句的话,直接从缓存中取,不再查数据库。一方面是减少了IO。另一方面不再执行繁琐的查找算法。效率大大提升。

mybatis缓存包括:
● 一级缓存:将查询到的数据存储到SqlSession中。
● 二级缓存:将查询到的数据存储到SqlSessionFactory中。
● 或者集成其它第三方的缓存:比如EhCache【Java语言开发的】、Memcache【C语言开发的】等。

2.一级缓存

2.1 原理

一级缓存默认是开启的。不需要做任何配置。
原理:只要使用同一个SqlSession对象执行同一条SQL语句,就会走缓存。

测试程序:

    @Test
    public void testSelectById(){
        SqlSession sqlSession = SqlSessionUtil.openSession();
        CarMapper mapper1 = sqlSession.getMapper(CarMapper.class);
        Car car1 = mapper1.selectById(34L);
        CarMapper mapper2 = sqlSession.getMapper(CarMapper.class);
        Car car2 = mapper2.selectById(34L);
        System.out.println(car1);
        System.out.println(car2);
        sqlSession.close();
    }

【SSM】MyBatis(十二.缓存)_第1张图片

2.2 什么时候不走缓存

● 第一种:不同的SqlSession对象。
● 第二种:查询条件变化了。

2.3 一级缓存失效

(1)方式一:第一次查询和第二次查询之间,手动清空了一级缓存。

sqlSession.clearCache();

(2) 方式二:第一次查询和第二次查询之间,执行了增删改(insert delete update)操作

3.二级缓存

3.1 原理

二级缓存的对象是SqlSessionFactory

满足以下几个条件可使用
1.全局性地开启或关闭所有映射器配置文件中已配置的任何缓存。默认就是true,无需设置。
2. 在需要使用二级缓存的SqlMapper.xml文件中添加配置:
3. 使用二级缓存的实体类对象必须是可序列化的,也就是必须实现java.io.Serializable接口
4. SqlSession对象关闭或提交之后,一级缓存中的数据才会被写入到二级缓存当中。此时二级缓存才可用。

3.2 二级缓存的失效

二级缓存的失效:只要两次查询之间出现了增删改操作。二级缓存就会失效。【一级缓存也会失效】

3.3 二级缓存相关配置

二级缓存相关配置:

  1. eviction:指定从缓存中移除某个对象的淘汰算法。默认采用LRU策略。
    a. LRU:Least Recently Used。最近最少使用。优先淘汰在间隔时间内使用频率最低的对象。(其实还有一种淘汰算法LFU,最不常用。)
    b. FIFO:First In First Out。一种先进先出的数据缓存器。先进入二级缓存的对象最先被淘汰。
    c. SOFT:软引用。淘汰软引用指向的对象。具体算法和JVM的垃圾回收算法有关。
    d. WEAK:弱引用。淘汰弱引用指向的对象。具体算法和JVM的垃圾回收算法有关。
  2. flushInterval:
    a. 二级缓存的刷新时间间隔。单位毫秒。如果没有设置。就代表不刷新缓存,只要内存足够大,一直会向二级缓存中缓存数据。除非执行了增删改。
  3. readOnly:
    a. true:多条相同的sql语句执行之后返回的对象是共享的同一个。性能好。但是多线程并发可能会存在安全问题。
    b. false:多条相同的sql语句执行之后返回的对象是副本,调用了clone方法。性能一般。但安全。
  4. size:
    a. 设置二级缓存中最多可存储的java对象数量。默认值1024。

你可能感兴趣的:(SSM,mybatis,缓存,java)