aspnet东莞网站建设价格,wordpress get_pages 输出格式,开工作室需要什么条件,网页制作教程素材Mybatis作为一款强大的ORM框架#xff0c;其中也用到了缓存来加速查询#xff0c;今天我们一起来探讨下。 Mybatis可以使用懒加载来提高查询的效率#xff0c;并且可以通过缓存来提高查询的效率。其中包括有一级缓存和二级缓存。 一级缓存是sqlSession级别的缓存#xff0c… Mybatis作为一款强大的ORM框架其中也用到了缓存来加速查询今天我们一起来探讨下。 Mybatis可以使用懒加载来提高查询的效率并且可以通过缓存来提高查询的效率。其中包括有一级缓存和二级缓存。 一级缓存是sqlSession级别的缓存这里先介绍一下SqlSession。
SqlSession是mybatis的重要构建之一可以类比为我们用jdbc所生成的connection这里我们通过SqlSession可以实现增删改查。不过现在更加推荐使用mapper的形式。
SqlSession提供select/insert/update/delete方法在旧版本中使用使用SqlSession接口的这些方法但是新版的Mybatis中就会建议使用Mapper接口的方法。从底层实现来说通过动态代理技术让接口跑起来之后采用命令模式最后还是采用了SqlSession的接口方法getMapper()方法等到Mapper执行SQL查询也就是说Mapper接口方法的实现底层还是采用SqlSession接口方法实现的。
以上的描述对简单其实实现起来还是箱单复杂的。
一级缓存是SqlSession级别的缓存。在操作数据库时需要构造sqlSession对象在对象中有一个数据结构HashMap用于存储缓存数据。不同的sqlSession之间的缓存数据区域HashMap是互相不影响的。
二级缓存是mapper级别的缓存多个SqlSession去操作同一个Mapper的sql语句多个SqlSession可以共用二级缓存二级缓存是跨SqlSession的基于nameSpace。