mybatis的一级缓存与二级缓存
什么叫缓存:
将数据存放在程序内存中,用于减轻数据查询的压力,
提升读取数据的速度,提高性能。
一级缓存:
一级缓存只是相对于同一个SQLSession而言。所以在参数
和SQL完全一样的情况下,我们使用同一个SQLSession对象调用
调用一个Mapper方法,往往只执行一次SQL,因为使用SQLSession
第一次查询后,mybatis会将其放在缓存中,以后再查询的时候,
如果没有声明需要刷新,并且缓存没有超市的情况下,SQLSession
都会取出当前缓存的数据,而不会再次发送SQL到数据库。
怎么判断某两次查询是完全相同的查询?
1.传入的statementID一致
2.查询是要求的结果集中的结果范围一致
3.传递的参数值一致
二级缓存:
mybatis的二级缓存是Application级别的缓存,它可以提高对
数据库查询的效率,以提高应用的性能。
二级缓存是Mapper级别的缓存,多个SQLSession去操作
同一个Mapper的SQL语句,多个SQLSession去操作数据库得到
数据会存在二级缓存区域,多个SQLSession可以共用二级缓存,
二级缓存是跨SQLSession的。
二级缓存是多个SQLSession共享的,其作用域是Mapper的
同一个namespace,不同的SQLSession两次执行相同namespace
下的SQL语句且向SQL中传递参数也相同最终执行相同的SQL语句,
第一次执行完毕会将数据库中查询的数据写到缓存(内存),
第二次会从缓存中获取数据将不再从数据库查询,从而提高查询
效率。mybatis默认没有开启二级缓存需要在xml配置文件中配置
开启二级缓存。mybatis要求返回的bean必须实现Serializable
接口。