mybatis-7-缓存
1. 一级缓存: SqlSession 级别, 默认开启, 并且不能关闭
操作数据库是需要创建 SqlSession 对象, 在对象中有一个 HashMap 用于存储缓存数据, 不同的 SqlSession 之间缓存数据区域互不影响.
一级缓存的做用户是 SqlSession 范围的, 当在同一个 SqlSession 中执行两次相同的 SQL 语句时, 第一次执行完毕会将结果保存到缓存中, 第二次查询时直接从缓存中获取.
需要注意的是, 如果 SqlSession 执行了 DML 操作(insert, update, delete), MyBatis 必须将缓存清空以保证数据的准确性.
举例说明, 如下代码查询两次, 但只会执行一次 SQL: (第二次查询是从缓存中拿的数据)
2、二级缓存
二级缓存(second level cache),全局作用域缓存
二级缓存默认不开启,需要手动配置
MyBatis提供二级缓存的接口以及实现,缓存实现要求 POJO实现Serializable接口
二级缓存在 SqlSession 关闭或提交之后才会生效