mybtis缓存
mybtis有两种缓存,一级缓存和二级缓存
Mybatis的一级缓存
一级缓存是sqlSession级别的,通过一个sqlSession查询的数据会被缓存,下次查询相同的数据,们就会从缓存中直接获取,不会从数据库重新访问
一级缓存默认开启
一级缓存失效的四种情况:
1.不通的sqlSession对应不同的一级缓存
2.同一个sqlSession但是查询条件不通
3.同一个sqlSession两次查询期间,执行了任一依次增删改操作
4.同一个sqlSession两次查询期间手动清空了缓存
Mybatis的二级缓存
二级缓存是sqlSessionFactory级别,通过同一个sqlSessionFactory创建的sqlSession查询的结果会被缓存,此后若再次执行相同的查询语句,结果就会从缓存中获取
二级缓存的条件:
1.在核心配置文件中,设置全局配置属性cacheEnabled=“true”,模式是true不需要配置
2.在映射文件中设置< cache />
3.二级缓存必须在sqlSession关闭和提交之后有效
4.查询的数据所转换的实体类型必须实现序列化的接口
二级缓存失效的情况:
两次查询之间执行了任意的增删改,会使一级和二级缓存同时失效