1、在⼀个sqlSession中,对User表根据id进行两次查询,查看他们发出sql语句的情况。
为泰宁等地区用户提供了全套网页设计制作服务,及泰宁网站建设行业解决方案。主营业务为网站建设、成都网站制作、泰宁网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!
2、同样是对user表进⾏两次查询,只不过两次查询之间进⾏了⼀次update操作。
3、总结
(1)第⼀次发起查询⽤户id为1的⽤户信息,先去找缓存中是否有id为1的⽤户信息,如果没有,从数据库查询⽤户信息。得到⽤户信息,将⽤户信息存储到⼀级缓存中。
(2)如果中间sqlSession去执⾏commit操作(执⾏插⼊、更新、删除),则会清空SqlSession中的⼀级缓存,这样做的目的为了让缓存中存储的是最新的信息,避免脏读。
(3)第⼆次发起查询用户id为1的⽤户信息,先去找缓存中是否有id为1的⽤户信息,缓存中有,直接从缓存中获取用户信息
⼆级缓存的原理和⼀级缓存原理一样,第⼀次查询,会将数据放⼊缓存中,然后第⼆次查询则会直接去缓存中取。
但是⼀级缓存是基于sqlSession的,⽽⼆级缓存是基于mapper⽂件的namespace的,也就
是说多个sqlSession可以共享⼀个mapper中的⼆级缓存区域,并且如果两个mapper的namespace相同,即使是两个mapper,那么这两个mapper中执⾏sql查询到的数据也将存在相同的⼆级缓存区域中。
网页名称:MyBatis:MyBatis一二级缓存,你学会了吗?
转载来源:http://www.shufengxianlan.com/qtweb/news42/246742.html
网站建设、网络推广公司-创新互联,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等
声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联