`
spjich
  • 浏览: 95311 次
  • 性别: Icon_minigender_1
社区版块
存档分类
最新评论

关于Mybatis一级缓存

    博客分类:
  • j2ee
阅读更多

关于Mybatis一级缓存的介绍 https://yq.aliyun.com/articles/18678 这篇已经介绍的非常详尽了。

但是读完以后我产生了一个疑问,如果在同一个session中2次相同的数据库操作之间,DB里的数据改变了,Mybatis一级缓存如何确保数据一致性,带着以上疑问我做了如下实验:

 

1.方法级别没有开启@Transactional,Mybatis查询记录如下

 测试函数:

在以下函数第四行处会打一个端点,在断点期间,我会手工进行数据库操作

    public String getTest() {
        List<String> s=dao.getTest();
        System.out.println(s.size());
        List<String> s2=dao.getTest();
        System.out.println(s2.size());
        return "ok";
    }

日志打印

 



 

 

 第一次打印1,由于没有开启事物控制,所以session被关闭,第二次dao查询又重新开启了一次sqlsession,所以没有走一级缓存

 

 

 

 

 

2.方法级别开启了@Transactional,Mybatis查询记录如下

测试函数:

在以下函数第四行处会打一个端点,在断点期间,我会手工进行数据库操作

    @Transactional
    public String getTest() {
        List<String> s=dao.getTest();
        System.out.println(s.size());
        List<String> s2=dao.getTest();
        System.out.println(s2.size());
        return "ok";
    }

 



 

  可见第二次Dao实际是从缓存中获得数据,所以拿到的数据量还是1行,即使我已经在库中插入了2条username='186251732**'的记录 

 

 

 

 

结论:

Mybatis一级缓存在无事物的情况下确实提高了效率减轻了DB压力,但是在事物的里也会存在数据不一致的问题,必要时候需要采取一定的手段(数据库锁,线程锁)来保证数据一致性

 

  原创文章,转载请声名出处  http://spjich.iteye.com/admin/blogs/2353479

 

  • 大小: 253.7 KB
  • 大小: 311.4 KB
0
0
分享到:
评论

相关推荐

    深入理解MyBatis中的一级缓存与二级缓存

    "深入理解MyBatis中的一级缓存与二级缓存" MyBatis是一种流行的持久层框架,它提供了缓存机制来提高应用程序的性能。在MyBatis中,有两种类型的缓存:一级缓存和二级缓存。下面我们将深入了解MyBatis中的一级缓存和...

    mybatis一级缓存和二级缓存简单示例

    本文将深入讲解 MyBatis 的一级缓存和二级缓存,并通过一个简单的示例进行说明。 ### 一级缓存 一级缓存是 Session 级别的缓存,也称为本地缓存(Local Cache)。每当我们在一个 SqlSession 中执行了 CRUD 操作,...

    springMybatis+redis三级缓存框架

    如果一级缓存中未找到所需数据,系统会查询二级缓存(Redis)。如果二级缓存中也没有,那么数据将从数据库中获取,并同时存入一级和二级缓存,形成三级缓存机制。 集成Spring和MyBatis可以利用Spring的依赖注入和...

    mybatis二级缓存学习

    MyBatis的一级缓存是SqlSession级别的,同一个SqlSession内的多次查询会复用之前的结果,避免了重复执行SQL。然而,当SqlSession关闭或提交时,一级缓存就会被清空。二级缓存则是在Mapper(或Namespace)级别,跨...

    从0到1项目搭建-集成 Redis 配置MyBatis二级缓存

    基于 SpringBoot 从0搭建一个企业级开发项目,基于SpringBoot 的项目,并集成MyBatis-Plus、Redis、Druid、Logback ,并使用 Redis 配置 MyBatis 二级缓存。

    MyBatis缓存(一级缓存、二级缓存)

    缓存是MyBatis性能优化的重要手段,分为一级缓存和二级缓存。在这篇文章中,我们将深入探讨这两个级别的缓存机制及其工作原理。 **一级缓存** 一级缓存是SqlSession级别的缓存,也称为局部缓存。当你执行一个查询...

    mybatis二级缓存

    MyBatis一级缓存是SqlSession级别的,而二级缓存则是在整个Mapper配置范围内的全局缓存,可以跨SqlSession共享数据。 在MyBatis中,二级缓存的实现原理如下: 1. 数据读取时,如果命中二级缓存,直接从内存中返回...

    mybatis二级缓存扩展-与redis集成

    在大型系统中,为了提高数据访问效率,MyBatis提供了二级缓存机制。本文将深入探讨如何对MyBatis的二级缓存进行扩展,并将其与Redis集成,以充分利用分布式缓存的优势。 MyBatis的二级缓存是基于全局的,它允许不同...

    mybatis一二级缓存

    在 MyBatis 中,一级缓存和二级缓存是两个重要的性能优化手段,它们可以有效减少对数据库的访问,提高系统的响应速度。下面将详细阐述这两个缓存机制。 ### 一级缓存 一级缓存是 MyBatis 默认开启的本地会话缓存,...

    Mybatis的以及缓存和二级缓存(案例).mhtml

    此文章是对Mybatis框架的一级缓存一级二级缓存的描述,包括他们的作用,案例,以及部分源码分析,对一级缓存以及二级缓存进行了详细的描述以及概括,还有如何使用等内容

    MyBatis 二级缓存 关联刷新实现

     Mybatis提供对缓存的支持,但是在没有配置的默认情况下,它只开启一级缓存,二级缓存需要手动开启。  一级缓存只是相对于同一个SqlSession而言。也就是针对于同一事务,多次执行同一Mapper的相同查询方法,第一...

    MyBatis一级缓存避坑完全指南

    MyBatis一级缓存避坑完全指南 MyBatis一级缓存是MyBatis框架中的一种缓存机制,用于提高数据库查询的性能。缓存的作用域为一次会话中,缓存随着会话(SqlSession)的创建而产生,随着会话结束而释放。在一次会话中,...

    深入了解MyBatis二级缓存

    其中,二级缓存是MyBatis中的一种高级缓存机制,它可以将查询结果缓存在内存中,以便下次查询时直接从缓存中获取结果,减少数据库查询次数,提高应用程序的性能。本文将深入了解MyBatis二级缓存,探索其工作原理、...

    mybatis一级二级缓存流程图.drawio

    mybatis一级二级缓存流程图.drawio mybatis一级二级缓存流程图.drawio mybatis一级二级缓存流程图.drawio mybatis一级二级缓存流程图.drawio

    mybatis+redis缓存配置

    MyBatis提供了两种级别的缓存支持:一级缓存和二级缓存。 - **一级缓存**:也称为本地会话缓存,它的生命周期是伴随着一次会话(SqlSession)的开始和结束。一级缓存默认开启且无法关闭,主要用于减少同一个会话内...

    MyBatis-05 缓存机制

    本篇文章将详细探讨MyBatis的缓存机制,包括一级缓存和二级缓存,以及如何将MyBatis与第三方缓存EhCache进行整合。 首先,我们来了解一级缓存。一级缓存是SqlSession级别的,也称为本地缓存。当我们在一个...

    深入了解MyBatis二级缓存共6页.pdf.zip

    MyBatis的一级缓存默认存在于SqlSession级别,而二级缓存则是一个全局性的缓存,跨会话共享,可以显著提升多用户环境下数据读取的效率。 MyBatis的二级缓存由两个主要组件构成:配置(Configuration)和映射器...

    MyBatis3开启二级缓存

    MyBatis的缓存分为一级缓存和二级缓存。一级缓存是SqlSession级别的,同一个SqlSession内的相同SQL语句不会重复执行,而是直接从缓存中获取结果。然而,一级缓存存在生命周期问题,当SqlSession关闭时,一级缓存就会...

    基于Java的Mybatis二级缓存memcache设计源码

    Mybatis二级缓存memcache项目源码,共20个文件,全部采用Java语言编写,涉及多种文件类型如Java源代码、XML配置...该项目是一个基于Java的Mybatis二级缓存memcache设计,旨在提供一个高效、稳定的二级缓存解决方案。

Global site tag (gtag.js) - Google Analytics