美文网首页
Mybatis缓存

Mybatis缓存

作者: 架构师奶爸 | 来源:发表于2020-10-28 16:12 被阅读0次

    Mybatis 中有一级缓存和二级缓存,默认情况下一级缓存是开启的,而且是不能关闭的。一级缓存是指SqlSession 级别的缓存,当在同一个SqlSession 中进行相同的SQL 语句查询时,第二次以后的查询不会从数据库查询,而是直接从缓存中获取,一级缓存最多缓存1024 条SQL。二级缓存是指可以跨SqlSession 的缓存。是mapper 级别的缓存,对于mapper 级别的缓存不同的sqlsession 是可以共享的。

    image.png

    Mybatis 的一级缓存(sqlsession 级别)

    第一次发出一个查询sql,sql 查询结果写入sqlsession 的一级缓存中,缓存使用的数据结构是一个map。
    key:MapperID+offset+limit+Sql+所有的入参
    value:用户信息
    同一个sqlsession 再次发出相同的sql,就从缓存中取出数据。如果两次中间出现commit 操作(修改、添加、删除),本sqlsession 中的一级

    二级缓存原理 (mapper 级别)

    二级缓存的范围是mapper 级别(mapper 同一个命名空间),mapper 以命名空间为单位创建缓存数据结构,结构是map。mybatis 的二级缓存是通过CacheExecutor 实现的。CacheExecutor其实是Executor 的代理对象。所有的查询操作,在CacheExecutor 中都会先匹配缓存中是否存
    在,不存在则查询数据库。
    key:MapperID+offset+limit+Sql+所有的入参。

    二级缓存具体在使用的时候需要配置:

    1. Mybatis 全局配置中启用二级缓存配置
    2. 在对应的Mapper.xml 中配置cache 节点
    3. 在对应的select 查询节点中添加useCache=true

    相关文章

      网友评论

          本文标题:Mybatis缓存

          本文链接:https://www.haomeiwen.com/subject/ufccvktx.html