一级缓存
一级缓存默认开启,一级缓存是和SqlSession绑定的,只存在于SQLSession的生命周期中,且任何的修改操作都会清空一级缓存。
二级缓存
二级缓存可以理解为存在于SqlSessionFactory的生命周期中,需要配置才能生效,且只有当调用SqlSession的close方法后,SqlSession才会保存查询数据到二级缓存中,在这之后才有了缓存数据。
配置二级缓存
在配置文件中设置cache-enabled为true即可开启二级缓存。开启之后默认如下效果:
映射文件中所有查询都会被缓存,所有修改语句都会刷新缓存。
缓存会使用Least Recently Used(LRU 最近最少使用)算法回收。
缓存没有刷新时间;缓存存储集合或者对象默认为1024个。
缓存对象可读可写,意味着可以安全的被修改。
修改默认效果
修改二级缓存的默认配置可在Mapper接口中或者xml文件中配置,Mapper接口中可以用cachenamespace标签配置,xml中可以使用cache标签配置,且两者同时配置时会报错。
正确使用姿势
为了保证Mapper中和xml中使用相同的缓存,一般是在Mapper中使用CacheNamespaceRef注解指定,然后在xml的cache标签中设置配置。如下图1
图1
注意事项
如果配置可读可写对象,那么对象都必须继承serializable接口。
如果配置只读对象,那么获取的都是对单个对象的引用,所以其他方法在修改对象时会造成脏数据。