mybatis分为一级缓存(存在内存中)和二级缓存(存在硬件中)
mybatis默认开启一级缓存,如果用同样的SqlSession对象查询相同的数据,则只会在第一次查询时向数据库发送sql语句,并将查询的结果放入到SqlSession中,后续查询,都从SqlSession中获取查询结果。
二级缓存,mybatis默认没有开启二级缓存,需要手动配置。
在mybatis.xml文件中配置
<!--声明开启二级缓存->
<setting name = "cacheEnabled" value = "true"/>
需要二级缓存完全生效,还需要在具体的mapper.xml 中配置
<!--声明此namespace开启二级缓存-->
<cache/>
且需要将准备缓存的对象序列化 ,否则会报异常 NotSerializableException
触发将对象写入缓存的时机:SqlSession对象的close()方法
二级缓存的范围是 namespace(包名.类名)
SqlSession对象只要执行了commit()方法,将会清除所有缓存
网友评论