mybatis的二级缓存

简介: ⼆级缓存是namespace级别的,多个SqlSession去操作同⼀个namespace下的Mapper的sql语句,同一个namespace下的多个SqlSession可以共⽤⼆级缓存,即同一个mapper标签下的CRUD语句共用二级缓存。

公众号merlinsea


简介:⼆级缓存是namespace级别的,多个SqlSession去操作同⼀个namespace下的Mapper的sql语句,同一个namespace下的多个SqlSession可以共⽤⼆级缓存,即同一个mapper标签下的CRUD语句共用二级缓存。


访问缓存的优点:数据库是基于磁盘来存放数据的,因此访问数据库的性能开销可以可以分为建立数据库连接+磁盘访问IO的开销;mybatis中的缓存是基于内存的,计算机访问内存的速度要远快于访问磁盘的速度,因此单位时间内通过内存来提供读数据服务要远快于通过磁盘来读取数据服务,提供的并发访问量级也会更高,这也是为什么要开启缓存的原因——提高并发访问量。


底层数据结构:基于PerpetualCache 的 HashMap本地缓存,和一级缓存一致。


默认不开启二级缓存。


缓存淘汰策略:当二级缓存空间满的时候会使⽤ LRU 算法来收回。


二级缓存失效情况:执⾏同个namespace下的mapepr映射⽂件中增删改sql,并执⾏了commit操作,会清空该⼆级缓存。


1、在mybatis的全局配置文件mybatis-config.xml中开启二级缓存总开关


<!--下划线自动映射驼峰字段-->
<settings>
    <setting name="mapUnderscoreToCamelCase" value="true"/>
    <!--这个配置使全局的映射器(二级缓存)启用或禁用缓存,全局总开关,这里关闭,mapper中开启了也没用-->
    <setting name="cacheEnabled" value="true" />
</settings>


2、在mapper.xml文件中开启mapperc层的二级缓存


<mapper namespace="net.xdclass.online_class.dao.VideoMapper"
    <sql id="base_video_field">
        id,title,summary,cover_img
    </sql>
    <!--在这个mapper下面的同一个namespace中开启二级缓存-->
    <cache eviction="LRU" flushInterval="100000" readOnly="true" size="1024"/>
    <select id="selectById" parameterType="java.lang.Integer" resultType="Video">
        select <include refid="base_video_field"/>  from video where id = #{video_id,jdbcType=INTEGER}
    </select>
</mapper>


3、使用二级缓存的demo

走二级缓存的条件:同一个namespace下的同一个sql语句。


public class SqlSessionCacheDemo {
    public static void main(String [] args) throws IOException {
        String resouce = "config/mybatis-config.xml";
        //读取配置文件
        InputStream inputStream =  Resources.getResourceAsStream(resouce);
        //构建Session工厂
        SqlSessionFactory sqlSessionFactory = new SqlSessionFactoryBuilder().build(inputStream);
        //获取Session
        try{
            /**
             * 第一次回去数据库中找,找到以后会放入二级缓存中
             */
            SqlSession sqlSession1 = sqlSessionFactory.openSession();
            VideoMapper videoMapper1 =  sqlSession1.getMapper(VideoMapper.class);
            Video video1 = videoMapper1.selectById(1);
            System.out.println(video1.toString());
            sqlSession1.commit();
            /**
             * 第二次由于是同一个namespace下的同一个sql语句,因此会走二级缓存
             */
            SqlSession sqlSession2 = sqlSessionFactory.openSession();
            VideoMapper videoMapper2 =  sqlSession2.getMapper(VideoMapper.class);
            Video video2 = videoMapper2.selectById(1);
            System.out.println(video2.toString());
            sqlSession2.commit();
        }catch (Exception e){
            e.printStackTrace();
        }
    }
}

640.png


相关文章
|
7月前
|
缓存 Java 数据库连接
Mybatis缓存相关面试题有多卷
使用 MyBatis 缓存机制需要注意以下几点: 对于频繁更新和变动的数据,不适合使用缓存。 对于数据的一致性要求比较高的场景,不适合使用缓存。 如果配置了二级缓存,需要确保缓存的数据不会影响到其他业务模块的数据。 在使用缓存时,需要注意缓存的命中率和缓存的过期策略,避免缓存过期导致查询性能下降。
110 0
|
3月前
|
缓存 Java 数据库连接
mybatis复习05,mybatis的缓存机制(一级缓存和二级缓存及第三方缓存)
文章介绍了MyBatis的缓存机制,包括一级缓存和二级缓存的配置和使用,以及如何整合第三方缓存EHCache。详细解释了一级缓存的生命周期、二级缓存的开启条件和配置属性,以及如何通过ehcache.xml配置文件和logback.xml日志配置文件来实现EHCache的整合。
mybatis复习05,mybatis的缓存机制(一级缓存和二级缓存及第三方缓存)
|
13天前
|
缓存 Java 数据库连接
MyBatis缓存机制
MyBatis提供两级缓存机制:一级缓存(Local Cache)默认开启,作用范围为SqlSession,重复查询时直接从缓存读取;二级缓存(Second Level Cache)需手动开启,作用于Mapper级别,支持跨SqlSession共享数据,减少数据库访问,提升性能。
24 1
|
17天前
|
缓存 Java 数据库连接
深入探讨:Spring与MyBatis中的连接池与缓存机制
Spring 与 MyBatis 提供了强大的连接池和缓存机制,通过合理配置和使用这些机制,可以显著提升应用的性能和可扩展性。连接池通过复用数据库连接减少了连接创建和销毁的开销,而 MyBatis 的一级缓存和二级缓存则通过缓存查询结果减少了数据库访问次数。在实际应用中,结合具体的业务需求和系统架构,优化连接池和缓存的配置,是提升系统性能的重要手段。
33 4
|
1月前
|
SQL 缓存 Java
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
本文详细介绍了MyBatis的各种常见用法MyBatis多级缓存、逆向工程、分页插件 包括获取参数值和结果的各种情况、自定义映射resultMap、动态SQL
【详细实用のMyBatis教程】获取参数值和结果的各种情况、自定义映射、动态SQL、多级缓存、逆向工程、分页插件
|
1月前
|
SQL 缓存 Java
MyBatis如何关闭一级缓存(分注解和xml两种方式)
MyBatis如何关闭一级缓存(分注解和xml两种方式)
69 5
|
6月前
|
SQL 缓存 Java
MYBATIS缓存
MYBATIS缓存
|
2月前
|
缓存 Java 数据库连接
使用MyBatis缓存的简单案例
MyBatis 是一种流行的持久层框架,支持自定义 SQL 执行、映射及复杂查询。本文介绍了如何在 Spring Boot 项目中集成 MyBatis 并实现一级和二级缓存,以提高查询性能,减少数据库访问。通过具体的电商系统案例,详细讲解了项目搭建、缓存配置、实体类创建、Mapper 编写、Service 层实现及缓存测试等步骤。
|
5月前
|
SQL 缓存 Java
【面试官】Mybatis缓存有什么问题吗?
面试官:你说下对MyBatis的理解?面试官:那SqlSession知道吧?面试官:Mybatis的缓存有哪几种?面试官:那Mybatis缓存有什么问题吗?面试官:Mybatis分页插件是怎么
【面试官】Mybatis缓存有什么问题吗?
|
5月前
|
缓存 算法 Java
关于MyBatis的缓存详解
MyBatis 的缓存机制非常灵活,可以通过简单的配置来满足不同的性能需求。合理地使用缓存可以显著提高应用程序的性能,尤其是在处理大量数据库查询时。然而,开发者需要注意缓存的一致性和并发问题,特别是在使用可读写缓存时。