MyBatis缓存的作用是提高系统性能,减少数据库交互次数,减轻数据库的压力。通过将查询结果缓存到内存中,可以避免重复查询数据库,从而提高系统的响应速度。
MyBatis的缓存原理是通过在SqlSession层和二级缓存层进行缓存控制。在SqlSession层,MyBatis使用PerpetualCache实现了一个基于HashMap的缓存模型,将查询结果缓存在内存中;在二级缓存层,MyBatis支持将缓存存储到外部缓存系统中,如Redis或Ehcache。
MyBatis的缓存机制基于以下原则:
- 默认情况下,MyBatis会为每个mapper的每个查询创建一个缓存,且缓存的生命周期与SqlSession的生命周期相同。
- 在同一个SqlSession中,如果两个查询的输入参数和SQL语句完全相同,则第二次查询将直接从缓存中获取结果,而不会再去执行数据库查询。
- 在同一个SqlSession中,如果两次查询之间进行了增删改的操作(如插入、更新、删除),则会清空该mapper的缓存。
需要注意的是,MyBatis的缓存机制是基于对象引用的,即缓存的是查询结果对象的引用,而不是拷贝。因此,在使用MyBatis缓存时要注意返回结果对象的可变性,避免在外部修改缓存对象导致其他查询结果也被影响。