Mybatis的一级缓存和二级缓存
时间: 2023-11-05 22:56:07 浏览: 92
Mybatis的一级缓存是SqlSession级别的缓存,存储在内存中,它默认是开启的,并且是自动管理的。当执行相同的查询语句时,一级缓存会直接返回缓存中的结果,而不会再次向数据库发送查询请求,从而提高查询性能。
而Mybatis的二级缓存是SqlSessionFactory级别的缓存,存储在磁盘中,需要手动进行配置和开启。二级缓存可以实现多个SqlSession之间的数据共享,提高缓存的可控性。但是使用二级缓存可能会出现错误数据,并且在分布式环境下可能会有数据不一致的问题,因此在分布式环境下不推荐使用二级缓存。
相关问题
mybatis一级缓存和二级缓存
MyBatis一级缓存和二级缓存区别如下:
一级缓存是SqlSession级别的缓存,当我们发起一次查询时,MyBatis会先到SqlSession缓存中查询是否有这个结果,如果有,直接返回缓存结果,如果没有,就去数据库中查询结果,查询完结果后,将结果放入SqlSession缓存中。
二级缓存是Mapper级别的缓存,当我们发起一次查询时,MyBatis会先到Mapper缓存中查询是否有这个结果,如果有,直接返回缓存结果,如果没有,就去数据库中查询结果,查询完结果后,将结果放入Mapper缓存中。二级缓存通常会开启,但是并不是所有的Mapper都需要开启二级缓存,需要根据具体情况进行配置。
mybatis 一级缓存和二级缓存
MyBatis 一级缓存是指在同一个 SqlSession 中,对同一个查询语句的多次执行会将第一次查询的结果缓存起来,后续执行相同查询语句时会直接从缓存中获取结果,而不是再次查询数据库。一级缓存的作用范围是 SqlSession,生命周期与 SqlSession 相同。
MyBatis 二级缓存是指在多个 SqlSession 中,对同一个查询语句的多次执行会将第一次查询的结果缓存起来,后续执行相同查询语句时会直接从缓存中获取结果,而不是再次查询数据库。二级缓存的作用范围是 Mapper,生命周期与 Mapper 相同。需要注意的是,二级缓存需要手动开启和配置,而且只对查询语句有效。
阅读全文