一级缓存是sqlsession级别的缓存:当第一次查询id为1的用户信息时候,sqlsession会到一级缓存区域查询,如果没有相关数据,则从数据库里面查询,然后sqlsession将查询结果保存到一级缓存,在下一次查询中,如果sqlsession执行了commit操作,则会清空他的一级缓存,以此保证缓存中的信息是新的,避免发生涨肚,,如果没执行修改操作,下一次就从缓存中读取数据。
二级缓存:当出现上面 的情况无法使用一级缓存,可以使用二级缓存,二级缓存存在于mapper实例里面,多个实例访问一个缓存。增删改查同样会清空namespace下的全部缓存
本文详细解析MyBatis中的一级缓存和二级缓存工作原理。一级缓存基于SqlSession,遵循先进先出原则,能快速响应相同查询。二级缓存则在Mapper层面共享,覆盖更广范围,但需注意数据一致性问题。
767

被折叠的 条评论
为什么被折叠?



