Mybatis中如何实现一级缓存和二级缓存,针对这个问题,这篇文章详细介绍了相对应的分析和解答,希望可以帮助更多想解决这个问题的小伙伴找到更简单易行的方法。一、一级缓存
一级缓存是SqlSession级别的缓存。在操作数据库时需要构造sqlSession对象,在对象中有一个数据结构(HashMap)用于存储缓存数据。不同的sqlSession之间的缓存数据区域(HashMap)是互相不影响的。在同一个SqlSession下的同一条查询语句(参数也不变)会从缓存返回结果;更新语句(update、insert、delete)会刷新缓存。二、二级缓存二级缓存是基于 mapper文件的namespace的,也就是说多个sqlSession可以共享一个mapper中的二级缓存区域 香港云主机,并且如果两个mapper的namespace相同,即使是两个mapper,那么这两个mapper中执行sql查询到的数据也将存在相同的二级缓存区域中。二级缓存基于namespace。如果一个user表,有两个不同namespace的Mapper都对其进行查询和更改,则互相不可见,容易读到过期数据。关于Mybatis中如何实现一级缓存和二级缓存问题的解答就分享到这里了,希望以上内容可以对大家有一定的帮助,如果你还有很多疑惑没有解开,可以关注开发云行业资讯频道了解更多相关知识。
本文对power BI和Tableau各维度进行对比,帮助你更快地找到适合的产品。两大行业领导者的对比公司背景power BI主要基于高级Excel功能,包括Power Query,Power Pivot和Power View。Microsoft的兴趣在于为其…
免责声明:本站发布的图片视频文字,以转载和分享为主,文章观点不代表本站立场,本站不承担相关法律责任;如果涉及侵权请联系邮箱:360163164@qq.com举报,并提供相关证据,经查实将立刻删除涉嫌侵权内容。