MyBatis-缓存机制,从一级缓存到二级缓存
一级缓存,默认开启,作用域是一个SQLsession,如果中间有对数据更新则会清空。
二级缓存,手动开启,作用域是一个namespace,一个mapper,配置文件中
<setting name="cacheEnabled" value="true"/>
在标签< mapper >下面添加< cache/>标签即可;
新增,修改,删除语句会清空缓存。
采取LRU算法,最近最少使用 算法
会缓存1024个对象的引用
存在BUG 如在controller中修改了 下次查询缓存则是修改过的内容,解决办法是克隆一份集合或者对象再使用。
二级缓存关键说明:当关闭了SqlSession之后,才会将查询数据保存到二级缓存中(SqlSessionFactory)中,所以才有了上述的缓存命中率。
MyBatis的二级缓存默认采用的是Map的实现。
4,衍生其实,我们在开发中,可以集成第三方的缓存来保存MyBatis的二级缓存,常用的有EhCache和Redis
MyBatis的XML映射文件都有哪些标签
1,基本的CRUD标签,select|insert|updae|delete
2,引用标签: < resultMap>、< parameterMap>、< sql>、< include>、< selectKey>
3,动态SQL标签:trim | where | set | foreach | if | choose | when | otherwise | bind等,其中< sql>为sql片段标签,通过< include>标签引入sql片段