Mybatis缓存
Mybatis缓存
因为热爱,所以拼搏。 --RuiDer
前导必备
- 数据库 - Mybatis
Mybatis缓存
Mybatis提供缓存支持,志在提升开发的性能。数据库数据的索引一般是基于磁盘的,而内存和高速缓存相对磁盘的读写速度相当快,基本是磁盘读写数据的十倍。尤其在互联网开发中,追求速度,缓存为性能提供捷径。Mybatis缓存包括一级缓存和二级缓存,一级缓存基于SqlSession层面,二级缓存基于SqlSessionFactory层面。一级缓存和二级缓存
缓存:将sql语句select查询出来对应的POJO对象进行缓存,供后续SqlSession对象使用。 一级缓存 条件: - 同一个SqlSession对象 - 同一个sql查询语句 当同一个SqlSession对象进行两次相同select语句查询时,第一次会执行sql语句进行数据库的索引, 之后将所查询数据对应的POJO对象进行缓存;第二次执行相同参数的sql语句查询前,不会像第一次执行sql语句, 而是直接从缓存中索引数据对象。所以说,一级缓存是基于SqlSession的。不同的SqlSession对象的缓存不可以 共享,不能相互访问。为了解决相互共享问题,Mybatis提供二级缓存解决该问题。注意,一级缓存对每个SqlSession 对象要求他们在所有sql语句后必须执行commit语句,否则,不存在一级缓存。 二级缓存 条件: - 同一个SqlSessionFactory对象 - 不同的SqlSession对象 - 共享POJO对象、 二级缓存是相对SqlSessionFactory对象而言的,同一个SqlSessionFactory创建的不同的SqlSession对象, 可以共享该SqlSessionFactory下的所有POJO对象,也就是数据库数据的共享。但是二级缓存要求对应的POJO类需要实现 序列化,也就是实现java.io.Serializable接口。
一级缓存 和 二级缓存 的配置
一级缓存:Mybatis默认一级缓存,只要每个SqlSession对象执行commit语句,都会存在一级缓存。 二级缓存: <cache ...sql语句... /> 加入上述语句,就会开启二级缓存。二级缓存会进行序列化和反序列化的过程,所以说POJO 必须要实现Seriaizable接口。二级缓存cache元素会将select出来的POJO对象进行缓存,对于 insert,update,delete sql语句二级缓存会自动刷新。
二级缓存配置cache元素配置项
//cache接口源码 public interface Cache{ //获取缓存id public int getId(); //保存POJO对象,key为键,value为值 public void putObject(Object key,Object value); //获取POJO对象 public Object getObject(Object key); //清除缓存 void clear(); //获取缓存大小 public int getSize(); //获取读写锁,主要是多线程时使用 ReadWriteLock getReadWriteLock(); }
配置Redis或者MongoDB缓存处理
<cache type="com....RedisCache"> <property name="Host" value="localHost"> </cache>
我的博客
相关推荐
dongxurr 2020-07-26
无情的你无情的雨 2020-07-18
jimgreatly 2020-06-03
cnflat0 2020-04-25
微微撒 2020-04-18
技术驱动人生 2020-04-08
Justagreenonion 2020-03-27
zhiyuan0 2020-02-24
云之飞踢 2020-01-28
gwn00 2020-01-14
明月清风精进不止 2020-01-07
Justagreenonion 2020-01-05
manbucy 2014-05-20
javamagicsun 2019-12-17
栖梧桐 2019-12-13
javamagicsun 2019-12-04
GechangLiu 2016-11-23
flydoging 2019-11-05
Ashes 2019-11-05