1.一级缓存
一级缓存默认会启用,存在于 SqlSession 的生命周期中,在同一个SqlSession 中查询时, MyBatis会把执行的方法和参数通过算法生成缓存的键值,将键值和查询结果存入一个Map对象中。如果同一个SqlSession 中执行的方法和参数完全一致,则会返回缓存中的对象。任何的 INSERT 、UPDATE 、 DELETE 操作都会清空一级缓存。可以通过在select标签上配置flushCache=“true”关闭一级缓存
2.二级缓存
二级缓存存在于SqlSessionFactory的生命周期中,跨sqlSession。缓存是以namespace为单位的,不同namespace下的操作互不影响。setting参数 cacheEnabled,这个参数是二级缓存的全局开关,如果设置为 false,即使有后面的二级缓存配置,也不会生效;
开启二级缓存:
<cache eviction="lru" flushInterval="60000" size="512" readOnly="true"/>
效果如下:
映射语句文件中的所有 select 语句将会被缓存。
映射语句文件中的所有 insert,update 和 delete 语句会刷新缓存。
缓存会使用 Least Recently Used(LRU,最近最少使用的)算法来收回。
根据时间表(比如 no Flush Interval,没有刷新间隔), 缓存不会以任何时间顺序 来刷新。
缓存会存储列表集合或对象(无论查询方法返回什么)的 512个引用。
缓存会被视为是 read/write(可读/可写)的缓存
由于二级缓存是以namespace为单位,可能会出现脏读。比如在关联查询时候,有一个订单查询在namespaceA,查询订单的时候会关联查询订单详细,而还有一个查询、修改订单详细在namespaceB。这时候在查询订单时候,订单详细也缓存在namespaceA。这时候namespaceB中修改订单,但namespaceA中的订单详情不会变。