• MyBatis 一级缓存


    一级缓存

      它指的是mybatis中sqlsession对象的缓存。

      当我们执行查询后,查询的结果会同时存到sqlsession为我们提供的一块区域,该区域的结构是个map。

      当我们再次查询同样的数据,这样mybatis会去sqlsession中查看是否有,有的话会直接拿出来用。

      当sqlsession消失时,mybatis的一级缓存也就消失了。

      我们用一个测试类看看效果

      运行一下我们发现只发起了一次sql查询,也就是说第二次是从缓存查询的数据

      如果说第一次查询后我们关闭了sqlsession对象,那么就意味着缓存区域被关闭了

      这个时候两个user对象就不是同一个了,返回的是false

      且发起的查询是两次

       除了关闭sqlsession,sqlsession还提供了clearCache方法清空缓存 

    分析

      如果涉及数据的更新,mybatis是如何保持数据的一致呢?

      我们在两次查询中加入更新的操作

       运行一下我们可以看到,第二次查询没有在缓存里取,而是向数据库发起了新的查询

      这是为什么呢?

      那是因为MyBatis调用sqlsession的修改,添加,删除,commit,close方法会清空一级缓存。

      所以上面我们调用了updata方法,sqlsession的一级缓存就被清除了。

  • 相关阅读:
    Consul运行
    springcloud+Zookeeper测试
    解决:sql2005 安装完后 没有服务的问题
    asp.net dataTable添加列
    C#关闭word进程
    无法将类型为“Microsoft.Office.Interop.Word.ApplicationClass”的 COM 对象强制转换为接口类型“Microsoft.Office.Interop.Word._Application”
    C#网页采集
    C#计算时间差值
    C#播放声音
    C#打开得到路径
  • 原文地址:https://www.cnblogs.com/qq2210446939/p/13624479.html
Copyright © 2020-2023  润新知