⼀级缓存和⼆级缓存(⾯试题)
⼀级缓存基于sqlSession默认开启,在操作数据库时需要构造SqlSession对象,在对象中有⼀个HashMap⽤于存储缓存数据。不同的SqlSession之间的缓存数据区域是互相不影响的。
⼀级缓存的作⽤域是SqlSession范围的,当在同⼀个sqlSession中执⾏两次相同的sql语句时,第⼀次执⾏完毕会将数据库中查询的数据写到缓存(内存),
第⼆次查询时会从缓存中获取数据,不再去底层数据库查询,从⽽提⾼查询效率。
需要注意的是,如果SqlSession执⾏了DML操作(增删改),并且提交到数据库,MyBatis则会清空SqlSession中的⼀级缓存,这样做的⽬的是为了保证缓存中存储的是最新的信息,避免出现脏读现象。
当⼀个SqlSession结束后该SqlSession中的⼀级缓存也就不存在了。
关闭⼀级缓存后,再次访问,需要再次获取⼀级缓存,然后才能查数据,否则会抛出异常。多表查询sql语句面试题
⼆级缓存是mapper级别的缓存。使⽤⼆级缓存时,多个SqlSession使⽤同⼀个Mapper的sql语句去操作数据库,得到的数据会存在⼆级缓存区域,它同样是使⽤HashMap进⾏数据存储。相⽐⼀级缓存SqlSession,⼆级缓存的范围更⼤,多个Sqlsession可以共⽤⼆级缓存,⼆级缓存是跨SqlSession的。
⼆级缓存的作⽤域是mapper的同⼀个namespace。不同的sqlSession两次执⾏相同的namespace下的sql语句,且向sql中传递的参数也相同,即最终执⾏相同的sql语句,则第⼀次执⾏完毕会将数据库中查询的数据写到缓存,第⼆次查询会从缓存中获取数据,不再去底层数据库查询,从⽽提⾼效率。
在MyBatis配置⽂件(l)中开启⼆级缓存(详细过程⾃⼰百度搜索开启)
//value属性默认为false
在**l中开启当前mapper的namespace下的⼆级缓存
代表创建了⼀个LRU缓存,并每隔60秒刷新,最⼤存储512个对象,⽽且返回的对象被认为是只读的。
evicition收回策略,默认是LRU
(1)LRU最近最少使⽤策略,⼀处做长时间不被使⽤的对象。
(2)FIFO先进先出策略,按对象进⼊缓存的顺序来移除它们。
(3)SOFT软引⽤策略,移除基于垃圾回收器状态和软引⽤规则的对象。
(4)WEAK弱引⽤策略,更积极地移除基于垃圾收集器状态和弱引⽤规则的对象
版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。
发表评论