一 、一级缓存
1、Mybatis的一级缓存存在于SqlsSession的生命周期中,在同一个SqlSession中查询时,Mybatis会把执行的方法和参数通过计算生成缓存的键值,将键值和查询结果存在一个Map对象中,如果同一个SqlSession中执行的方法和参数完全一致,那么通过算法会生成相同的键值,当map缓存对象中已经存在该键值时。则会返回缓存中的对象。
为避免查询的数据不是数据库中最新的数据,需要看在select标签中加如下属性:flushCache='true' 例子如下:
<select id="selectById" flushCache="true" resultMap="userMap">
select * from sys_user where id=#{id}
</select>
2、任何的INSERT、UPDATE、DELETE操作都会清空一级缓存
二、二级缓存
1、Mybatis的二级缓存是和命名空间绑定的,即二级缓存需要配置在Mapper.xml映射文件中,或者配置在Mapper.java接口中。\
在Mybatis的全部配置中setting中有一个参数cacheEnabled,这个参数是二级缓存的全局开关,默认值是true,初始状态为启用状态。如果把这个参数设置为false,即使有后面的二级缓存配置,也不会生效。由于这个参数值默认为true,所以不必配置,如果想要配置,可以在mybatis-config.xml中添加如下代码
2、开启二级缓存全局配置(可有可无,默认开启)
<setting>
<setting name="cacheEnabled" value="true"/>
</setting>
3、XML配置二级缓存
在保证二级缓存的全局配置开启的情况下,给RoleMapper.xml开机二级缓存只需要在UserMapper.xml中添加<cache/>元素即可,添加后的UserMapper.xml如下:
<?xml version="1.0" encoding="UTF-8"?>
<!DOCTYPE mapper PUBLIC "-//mybatis.org//DTD Mapper 3.0 //EN"
"http://mybatis.org/dtd/mybatis-3-mapper.dtd">
<mapper>
<cache/>
<!--其他配置 -->
</mapper>
4、Mapper接口中配置二级缓存
@CacheNamespaceRef(RoleMapper.class)
public interface RoleMapper{
//其他接口
}
<mapper namesapce="tk.mybatis.simple.RoleMapper">
<cache
eviction="FIFO"
flushInterval="60000"
size="512"
readOnly="false"/>
</mapper>