mybatis缓存机制
时间: 2023-09-13 18:13:01 浏览: 92
MyBatis-05 缓存机制
MyBatis提供了两种级别的缓存机制:一级缓存和二级缓存。
一级缓存是MyBatis默认开启的缓存机制,它是基于SqlSession的生命周期的缓存。当我们执行查询操作时,MyBatis会将查询结果放入SqlSession的缓存中,下次再执行相同的查询,直接从缓存中获取结果,而不需要再去数据库查询。一级缓存是针对同一个SqlSession的,不同的SqlSession之间的缓存数据互不影响。
二级缓存是基于mapper级别的缓存机制,它可以跨SqlSession共享数据。当多个SqlSession执行相同的查询时,如果开启了二级缓存,MyBatis会先从二级缓存中查找数据,如果找到了则直接返回结果,如果没有找到则再去数据库查询,并将查询结果放入二级缓存中。二级缓存默认是关闭的,我们可以通过在mapper.xml文件中配置<cache>节点来开启和配置二级缓存。
需要注意的是,二级缓存是基于mapper级别的,每个mapper都有一个独立的二级缓存。如果有多个mapper对同一张表进行操作,那么在更新数据时需要手动清除或刷新二级缓存,以保证数据的一致性。
总结一下,MyBatis的缓存机制可以减少数据库的访问次数,提高系统性能。一级缓存是默认开启的,基于SqlSession的生命周期;二级缓存是可配置的,可以跨SqlSession共享数据,但需要注意数据的一致性。
阅读全文