前言
上节课我们学习了 MyBatis 延迟加载,可以有效减少 Java 程序与数据库的交互次数,从而提高程序的运行效率,但是延迟加载的功能并不全面,它只能在做级联查询的时候提高效率,如果现在的需求就是单表查询,那么延迟加载就无法满足需求了。不用担心,MyBatis 同样为我们提供了这种业务场景下的解决方案,即缓存。
使用缓存的作用也是减少 Java 应用程序与数据库的交互次数,从而提升程序的运行效率。比如第一次查询出某个对象之后,MyBatis 会自动将其存入缓存,当下一次查询同一个对象时,就可以直接从缓存中获取,不必再次访问数据库了,如下图所示。
MyBatis 有两种缓存:一级缓存和二级缓存。
MyBatis 自带一级缓存,并且是无法关闭的,一直存在,一级缓存的数据存储在 SqlSession 中,即它的作用域是同一个 SqlSession,当使用同一个 SqlSession 对象执行查询的时候,第一次的执行结果会自动存入 SqlSession 缓存,第二次查询时可以直接从缓存中获取。
但是如果是两个 SqlSession 查询两次同样的 S