缓存范围是跨SqlSession的,范围是mapper的namespace,相同的namespace使用一个二级缓存结构。
需要进行参数配置让mybatis支持二级缓存。
1.在全局的配置文件SqlMapConfig.xml中加入,表示打开二级缓存开关
2.
还需要在
mapper.xml
中配置是否打开该
mapper
的二级缓存。
二级缓存注意事项
1.实现序列号
注意:将查询结果的pojo对象进行序列化实现
2.如果清除缓存
如果执行提交操作需要清除二级缓存。
如果想让statement执行后刷新缓存(清除缓存),在statement中设置flushCache="true" (默认值 是true)
3. 设置statement是否开启二级缓存
如果让某个statement启用二级缓存,设置useCache=true(默认值为true)
二级缓存原理
如果二缓存开启,首先从二级缓存查询数据,如果二级缓存有则从二级缓存中获取数据,如果二级缓存没有,从一级缓存找是否有缓存数据,如果一级缓存没有,查询数据库。
二级缓存应用场景
1、针对复杂的查询或统计的功能,用户不要求每次都查询到最新信息,使用二级缓存,通过刷新间隔flushInterval设置刷新间隔时间,由mybatis自动刷新。
比如:实现用户分类统计sql,该查询非常耗费时间。
将用户分类统计sql查询结果使用二级缓存,同时设置刷新间隔时间:flushInterval(一般设置时间较长,比如30分钟,60分钟,24小时,根据需求而定)
2、针对信息变化频率高,需要显示最新的信息,使用二级缓存。
将信息查询的statement与信息的增、删、改定义在一个mapper.xml中,此mapper实现二级缓存,当执行增、删、修改时,由mybatis及时刷新缓存,满足用户从缓存查询到最新的数据。
比如:新闻列表显示前10条,该查询非常快,但并发大对数据也有压力。
将新闻列表查询前10条的sql进行二级缓存,这里不用刷新间隔时间,当执行新闻添加、
最佳的方案使用页面缓存。