1.一次sqlsession的作用范围
可以看做是一次db连接或者一个事务
当sqlsession close 或则 事务commit 一级缓存就被清理了
一级缓存的意义在于减少db连接次数:
在手写sqlsession查询的场景,多次查询只有第一次连接db,其余查询走缓存
常规的mybatis使用时,一级缓存基本没用
2.二级缓存的更新问题
更新时机:
更新数据时,使用 MyBatis 提供的 update delete insert 语句修改数据库
MyBatis在执行更新操作后,会自动地清理并更新二级缓存
实体类:需要支持序列化 因为二级缓存是基于序列化做的
数据不一致问题:二级缓存的作用范围是namespace,不一致问题主要是发生在多namespace
使用时需要慎重,特别是数据一致性要求高的场景,有很大风险,这也是为什么没有默认开启二级缓存的原因
具体使用:
1.mybatis配置文件mybatis-config.xml种添加setting配置:cacheEnabled:true
2.mapper种添加cache标签