Mybatis 延迟缓存,一级缓存,二级缓存
什么是延迟加载
resultMap中的association和collection标签具有延迟加载的功能。
延迟加载的意思是说,在关联查询时,利用延迟加载,先加载主信息。使用关联信息时再去加载关联信息。
设置延迟加载
需要在SqlMapConfig.xml文件中,在标签中设置下延迟加载。
lazyLoadingEnabled、aggressiveLazyLoading
一级缓存
一级缓存是基于sqlsession 作用域为sqlsession
一级缓存自动开启 无需手动添加
查询的时候会先去缓存里面寻找是否已经查询到数据 如果有 就不会发送sql语句 查询 效率更高 速度更快
二级缓存
二级缓存是mapper级别的。Mybatis默认是没有开启二级缓存。
开启二级缓存
在自己写的xml文件里面开启二级缓存
第一行是catch里面的属性 cache属性是默认的
父类需要一个序列化
在二级缓存里面 可以禁用 或者刷新二级缓存
在方法 下面 加上
userCache=false 即可禁用
刷新二级缓存
flushCache=true 即可即使刷新更改的数据