首页 > 其他分享 >有关Mybatis的缓存

有关Mybatis的缓存

时间:2022-09-23 15:47:11浏览次数:48  
标签:xml 缓存 对象 有关 namespace SqlSession Mybatis 操作

有关Mybatis的缓存

一级缓存

  • 默认开启
  • 只是相对于同一个SqlSession而言
  • 生命周期:
    • MyBatis在开启一个数据库会话时,会创建一个新的SqlSession对象,SqlSession对象中会有一个新的Executor对象,Executor对象中持有一个新的PerpetualCache对象;当会话结束时,SqlSession对象及其内部的Executor对象还有PerpetualCache对象也一并释放掉;
    • 如果SqlSession调用了close()方法,会释放掉一级缓存PerpetualCache对象,一级缓存将不可用;
    • 如果SqlSession调用了clearCache(),会清空PerpetualCache对象中的数据,但是该对象仍可使用;
    • SqlSession中执行了任何一个update操作(update()、delete()、insert()) ,都会清空PerpetualCache对象的数据,但是该对象可以继续使用;

二级缓存

  • 默认不开启

  • 缓存是以namespace为单位的,不同namespace下的操作互不影响;

  • insert,update,delete操作会清空所在namespace下的全部缓存;

  • 通常使用MyBatis Generator生成的代码中,都是各个表独立的,每个表都有自己的namespace;

  • 缓存是单服务器进行工作的,无法实现分布式缓存;

  • 注意事项:

    • 只能在【只有单表操作】的表上使用缓存多表操作一定不能使用缓存

      • 不只是要保证这个表在整个系统中只有单表操作,而且和该表有关的全部操作必须全部在一个namespace下;
    • 在可以保证查询远远大于insert,update,delete操作的情况下使用缓存

      • 这一点不需要多说,同时,这一点需要保证在1的前提下才可以!

避免使用二级缓存

针对一个表的某些操作不在他独立的namespace下进行,

例如在UserMapper.xml中有大多数针对user表的操作,但是在一个XXXMapper.xml中,还有针对user单表的操作。这会导致user在两个命名空间下的数据不一致。如果在UserMapper.xml中做了刷新缓存的操作,在XXXMapper.xml中缓存仍然有效,如果有针对user的单表查询,使用缓存的结果可能会不正确;

更危险的情况是在XXXMapper.xml做了insert,update,delete操作时,会导致UserMapper.xml中的各种操作充满未知和风险;

多表操作一定不能使用缓存

为什么不能? 首先不管多表操作写到那个namespace下,都会存在某个表不在这个namespace下的情况。 例如两个表:role和user_role,如果我想查询出某个用户的全部角色role,就一定会涉及到多表的操作。

<select id="selectUserRoles" resultType="UserRoleVO">
    select * from user_role a,role b where a.roleid = b.roleid and a.userid = #{userid}
</select>

像上面这个查询,不管是写到RoleMapper.xml还是UserRoleMapper.xml,或者是一个独立的XxxMapper.xml中,如果使用了二级缓存,都会导致上面这个查询结果可能不正确。 如果你正好修改了这个用户的角色,上面这个查询使用缓存的时候结果就是错的

标签:xml,缓存,对象,有关,namespace,SqlSession,Mybatis,操作
From: https://www.cnblogs.com/horseweed/p/16722946.html

相关文章

  • mybatis-plus使用selectPage查询数据时,total为0 的解决方案
    1:问题描述项目迁移,原本正常的mp的分页坏了,经过调试发现是total参数没有  2:原因这是mp需要设置分页拦截器才能生效的,所以只要注入一下拦截器即可3:解决把这段代码放......
  • mybatis不知道取什么名字的标题
    <!--根据多个id--><foreachcollection="ids"index="index"item="item"open="("separator=","close=")">#{item}</foreach><!--日期截取指定的-->......
  • 谈谈域名DNS的缓存问题
    域名解析不像空间绑定IP那样,能够即时生效,即时失效。每一个域名,在服务商那边都有一个DNS服务器,作用是把利于用户记忆的域名转换成计算机方便理解的IP地址,在域名管理中,其中......
  • mybatis的crud
    [查询]<!--根据条件查询-->select*fromtab1where1=1<iftest="field!=nullandfield!=''">andfieldlikeconcat('%',#{field},'%')</if><iftes......
  • 初探缓存装饰器
    平常学习过程发现了一个牛掰装饰器,在此记录下1fromfunctoolsimportlru_cache234@lru_cache()5defcount(a,b):6print("对{},{}求和".format(a,......
  • MyBatis——使用Mapper代理开发
    使用Mapper代理开发方式完成入门案例  1、定义与SQL映射文件同名的Mapper接口,并将Mapper接口和SQL映射文件放置在同一目录下      (企业开发中,通常是将配置文......
  • Mybatis日志
    一、mybatis日志1.关于日志作用:可以从控制台看到进程13:47:32.510[main]DEBUGorg.apache.ibatis.transaction.jdbc.JdbcTransaction-OpeningJDBCConnection1......
  • Mybatis缓存机制
    MyBatis是常见的Java数据库访问层框架。在日常工作中,多数情况下是使用MyBatis的默认缓存配置减轻数据库压力,提高数据库性能,但是MyBatis缓存机制有一些不足之处,在使用中容易......
  • MybatisPlus代码生成器
    1、导入依赖<dependency><groupId>com.baomidou</groupId><artifactId>mybatis-plus-generator</artifactId><version>3.5.1</version></dependency><d......
  • hcache查看系统缓存
    hcache查看系统缓存hcache是基于pcstat的,pcstat可以查看某个文件是否被缓存和根据进程pid来查看都缓存了哪些文件。hcache在其基础上增加了查看整个操作系统Cache和根据使......