如果数据库的数据和一级缓存的数据不一致了,怎么做到同步的呢? 增加一个更新 用户信息的方法 增加更新的节点配置 测试类增加测试方法.先查询id为41的 然后更新了41的数据.再次查询41的数据 先把更新代码剪切到测试. 由于有缓存的存在,所以只查了一遍 把更新的操作粘贴回来. 更新后的操作 又执行了新的select查询 也就是执行了update方法后,一级缓存被清空了..…
上一章节,我们讲解了通过mybatis的懒加载来提高查询效率,那么除了懒加载,还有什么方法能提高查询效率呢?这就是我们本章讲的缓存. mybatis 为我们提供了一级缓存和二级缓存,可以通过下图来理解: ①.一级缓存是SqlSession级别的缓存.在操作数据库时需要构造sqlSession对象,在对象中有一个数据结构(HashMap)用于存储缓存数据.不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的. ②.二级缓存是mapper级别的缓存,多个SqlSession去…
------------吾亦无他,唯手熟尔,谦卑若愚,好学若饥------------- 缓存------------------------------------------> 很熟悉的一个词,什么是缓存? 好多人都不太能解释清楚缓存的概念,运用到缓存的地方大家都很清楚,像什么网站了,视频缓存啊,等等 我从百度百科copy一个缓存的概念,读一下,免得看完这篇博客都对缓存的概念一无所知 缓存就是数据交换的缓冲区(称作Cache),当某一硬件要读取数据时,会首先从缓存中查找需要的数据,如果找到了…
之前的文章我已经基本讲解到了SqlSessionFactory.SqlSession.Excutor以及Mpper执行SQL过程,下面我来了解下myabtis的缓存, 它的缓存分为一级缓存和二级缓存,本文我们主要分析下一级缓存. 先看一个例子,代码还是之前(第一篇)的的demo     public static void main(String[] args) throws Exception {         SqlSessionFactory sessionFactory = null;…
二级缓存:             它指的是Mybatis中SqlSessionFactory对象的缓存.由同一个SqlSessionFactory对象创建的SqlSession共享其缓存.             二级缓存的使用步骤:                 第一步:让Mybatis框架支持二级缓存(在SqlMapConfig.xml中配置)                 第二步:让当前的映射文件支持二级缓存(在IUserDao.xml中配置)                 第三步…
Mybatis中的一级缓存和二级缓存         一级缓存:             它指的是Mybatis中SqlSession对象的缓存.             当我们执行查询之后,查询的结果会同时存入到SqlSession为我们提供一块区域中.             该区域的结构是一个Map.当我们再次查询同样的数据,mybatis会先去sqlsession中             查询是否有,有的话直接拿出来用.             当SqlSession对象消失时,myb…
正如大多数持久层框架一样,MyBatis同样提供了一级缓存和二级缓存的支持 1. MyBatis一级缓存基于PerpetualCache的HashMap本地缓存,其存储作用域为 Session,默认情况下,一级缓存是开启状态的.当 Session flush(); 或 close(); 之后,该Session中的所有 Cache 就将清空. 2.MyBatis二级缓存与一级缓存其机制相同,默认也是采用 PerpetualCache,HashMap存储,不同在于其存储作用域为 Mapper(Nam…
MyBatis的延迟加载.一级缓存.二级缓存设置 首先我们必须分清延迟加载的适用对象 延迟加载 MyBatis中的延迟加载,也称为懒加载,是指在进行关联查询时,按照设置延迟加载规则推迟对关联对象的select查询.延迟加载可以有效的减少数据库压力.  注意:MyBatis的延迟加载只是对关联对象的查询有延迟设置,对于主加载对象都是直接执行查询语句的. MyBatis根据对关联对象查询的select语句的执行时机,分为3种类型:1.直接加载2.侵入式延迟加载3.深度延迟加载 直接加载:执行完对主加…
首先需要明白,mybatis的一级缓存就是指SqlSession缓存,Map缓存! 通过前面的源码分析知道mybatis框架默认使用的是DefaultSqlSession,它是由DefaultSqlSessionFactory创建的,下面是源码 private SqlSession openSessionFromDataSource(ExecutorType execType, TransactionIsolationLevel level, boolean autoCommit) { Tran…
2.Mybatis中的缓存     什么是缓存         存在于内存中的临时数据.     为什么使用缓存         减少和数据库的交互次数,提高执行效率.     什么样的数据能使用缓存,什么样的数据不能使用         适用于缓存:             经常查询并且不经常改变的.             数据的正确与否对最终结果影响不大的.         不适用于缓存:             经常改变的数据             数据的正确与否对最终结果影响很大的.…