MyBatis 缓存的作用
使用缓存的作用:减少 Java 应用程序与数据库的交互次数,从而提升程序的运行效率。比如第一次查询出某个对象之后,MyBatis 会自动将其存入缓存,当下一次查询同一个对象时,就可以直接从缓存中获取,不必再次访问数据库了。
MyBatis 缓存的种类
两种:
- 一级缓存
- 二级缓存
1. 一级缓存:
MyBatis 自带一级缓存,并且是无法关闭的,一直存在,一级缓存的数据存储在 SqlSession 中,即它的作用域是同一个 SqlSession,当使用同一个 SqlSession 对象执行查询的时候,第一次的执行结果会自动存入 SqlSession 缓存,第二次查询时可以直接从缓存中获取。
注意:
- 但是如果是两个 SqlSession 查询两次同样的 SQL,一级缓存不会生效,需要访问两次数据库
- 同时需要注意,为了保证数据的一致性,如果 SqlSession 执行了增加、删除,修改操作,MyBatis 会自动清空 SqlSession 缓存中存储的数据。
- 一级缓存不需要进行任何配置,可以直接使用。
2. 二级缓存:
MyBatis 二级缓存是 Mapper 级别的,只要是同一个 Mapper,无论使用多少个 SqlSession 来操作,数据都是共享的。
MyBatis 二级缓存默认是关闭的,需要使用时可以通过配置手动开启。
实现(二级缓存的实现)
MyBatis 可以使用自带的二级缓存,也可以使用第三方的 ehcache 二级缓存。
1. 自带:
- config.xml 中配置开启二级缓存
- xxxMapper.xml 中配置二级缓存
- Classes 实体类实现 Serializable 接口
<configuration>
<!-- 设置 settings -->
<settings>
<!-- 开启二级缓存 -->
<setting name="cacheEnabled" value="true"/>
</settings>
</configuration>
<mapper namespace="...">
<!-- 配置 -->
<cache></cache>
<select id="findById" parameterType="long" resultType="....">
select * from classes where id = #{id}
</select>
</mapper>
public class xxx implements Serializable {
// .......
// .......
}
2. 第三方的 ehcache 二级缓存
- pom.xml 添加 ehcache 相关依赖
- 在 resources 路径下创建 ehcache.xml
- config.xml 中配置开启二级缓存
- xxxMapper.xml 中配置二级缓存
- 注意:实体类不需要实现 Serializable 接口
<dependencies>
<dependency>
<groupId>org.mybatis</groupId>
<artifactId>mybatis-ehcache</artifactId>
<version>1.0.0</version>
</dependency>
<dependency>
<groupId>net.sf.ehcache</groupId>
<artifactId>ehcache-core</artifactId>
<version>2.4.3</version>
</dependency>
</dependencies>
<ehcache xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:noNamespaceSchemaLocation="../config/ehcache.xsd">
<diskStore/>
<defaultCache
maxElementsInMemory="1000"
maxElementsOnDisk="10000000"
eternal="false"
overflowToDisk="false"
timeToIdleSeconds="120"
timeToLiveSeconds="120"
diskExpiryThreadIntervalSeconds="120"
memoryStoreEvictionPolicy="LRU">
</defaultCache>
</ehcache>
<configuration>
<!-- 设置settings -->
<settings>
<!-- 开启二级缓存 -->
<setting name="cacheEnabled" value="true"/>
</settings>
</configuration>
<mapper namespace="....">
<!-- 开启二级缓存 -->
<cache type="org.mybatis.caches.ehcache.EhcacheCache" >
<!-- 缓存创建以后,最后一次访问缓存的时间至失效的时间间隔 -->
<property name="timeToIdleSeconds" value="3600"/>
<!-- 缓存自创建时间起至失效的时间间隔-->
<property name="timeToLiveSeconds" value="3600"/>
<!-- 缓存回收策略,LRU 移除近期最少使用的对象 -->
<property name="memoryStoreEvictionPolicy" value="LRU"/>
</cache>
<select id="findById" parameterType="long" resultType="...">
select * from classes where id = #{id}
</select>
</mapper>