MyBatis 的一级缓存是指在同一个 SqlSession 中,查询操作的结果会被缓存在内存中,供后续的相同查询使用。一级缓存是 MyBatis 默认开启的,它的作用范围是 SqlSession 级别的。
以下是一级缓存的基本特点和工作原理:
- 特点:
- 一级缓存是在同一个 SqlSession 中有效的,不同的 SqlSession 之间相互独立。
- 一级缓存存储的是查询操作的结果对象,而不是数据表中的实际数据。
- 一级缓存默认开启,可以通过配置进行关闭或刷新。
- 工作原理:
- 当执行一个查询操作时(如select),MyBatis 会首先尝试从一级缓存中查找对应的结果对象。
- 如果找到了缓存中的结果对象,那么将直接返回缓存的结果,不再访问数据库。
- 如果缓存中没有对应的结果对象,那么 MyBatis 会执行数据库查询,并将查询结果放入一级缓存中,以便后续的相同查询可以直接使用。
- 在同一个 SqlSession 中,如果发生了数据修改操作(如insert、update、delete),会导致一级缓存被清空,以避免脏读的问题。
- 在同一个 SqlSession 中,可以使用clearCache()方法手动清空一级缓存。
需要注意的是,一级缓存的生命周期是与 SqlSession 相关的。当一个 SqlSession 结束(包括提交事务或关闭 SqlSession)后,一级缓存也会失效,其缓存的结果对象将被释放。因此,如果希望在多个 SqlSession 之间共享缓存,可以考虑使用二级缓存。
MyBatis 的二级缓存是指在不同的 SqlSession 间共享的缓存,它位于 Mapper 接口级别。默认情况下,二级缓存是关闭的,需要手动配置启用。
以下是关于 MyBatis 二级缓存的一些特点和配置方式:
- 特点:
- 二级缓存是跨 SqlSession 的,可以实现多个 SqlSession 之间的缓存共享。
- 二级缓存存储的是查询操作的结果对象,而不是数据表中的实际数据。
- 二级缓存是基于命名空间(Mapper 接口)的,不同的 Mapper 接口拥有独立的缓存空间。
- 二级缓存默认是关闭的,需要在 MyBatis 配置文件中手动配置开启。
- 配置方式:
- 在 MyBatis 的配置文件(如mybatis-config.xml)中,可以通过<cache>元素来配置二级缓存的开启和其他相关属性。
- 使用<cache/>表示启用默认配置的二级缓存,或者可以通过<cache type="自定义缓存实现类全限定名"/>来指定自定义的缓存实现类。
- 可以使用<select>、<insert>、<update>、<delete>标签的useCache属性来控制是否使用二级缓存。
- 注意事项:
- 二级缓存的作用范围是 Mapper 接口级别的,需要确保操作同一个 Mapper 接口的不同 SqlSession 才能共享缓存。
- 对于涉及到数据更新(如insert、update、delete)的操作,会导致二级缓存失效,需要重新读取数据库。
- 可以使用<cache-ref>元素来引用其他命名空间的缓存,实现缓存共享的更细粒度控制。
需要注意的是,尽管二级缓存可以带来性能上的提升,但同时也可能导致数据一致性和并发访问的问题。在使用二级缓存时,需要根据具体业务场景和需求来合理配置、使用和刷新缓存,以避免潜在的问题。