大家都知道Mybaits有两级缓存
- 一级缓存作用范围默认sqlsession级别,在并发中可能出现脏读,调整为statement可以避免。
- 二级缓存作用范围为namespace级别,在多表查询namespace不同时出现脏读,原因是aMapper中的方法获取到联查的数据后,如果被联查的表更新后aMapper是没有更新缓存的。
SpringCache可以提供key value形式的缓存,可以在根据id查询时以类名加id的形式也可以使用方法名、参数列表缓存在redis中,更新也可以根据类名加id进行更新。
我对Mybatis-Plus与SpringCache结合的想法:
Mybatis-Plus默认提供了很多方便查询的方法比如list、selectBatchIds等返回集合的方法,对于这种方法:某个返回集合的方法中根据方法名、参数列表缓存了n个对象,另一个方法中更新了这个集合中某一个对象(数据库中该对象已改变而集合中没有改变),再次查询返回集合的方法时由于缓存没有更新就会出现缓存与数据库数据不一致的脏读问题。要解决这中情况可以指定@CacheEvict的allEntries为true,清除所有value中的缓存。
而跨表的问题也可以当被关联对象更新时 指定关联该对象的方法的缓存 失效。
总而言之项目中对读多写少的业务关闭Mybatis二级缓存,使用SpringCache,将Mybatis-Plus所有的更新方法中设置allEntries=true。