Mybatis对缓存提供支持,可是在没有配置的默认状况下,它只开启一级缓存,一级缓存只是相对于同一个SqlSession而言。因此在参数和SQL彻底同样的状况下,咱们使用同一个SqlSession对象调用一个Mapper方法,每每只执行一次SQL,由于使用SelSession第一次查询后,MyBatis会将其放在缓存中,之后再查询的时候,若是没有声明须要刷新,而且缓存没有超时的状况下,SqlSession都会取出当前缓存的数据,而不会再次发送SQL到数据库。数据库
为何要使用一级缓存,不用多说也知道个大概。可是还有几个问题咱们要注意一下。缓存
一、一级缓存的生命周期有多长?app
a、MyBatis在开启一个数据库会话时,会 建立一个新的SqlSession对象,SqlSession对象中会有一个新的Executor对象。Executor对象中持有一个新的PerpetualCache对象;当会话结束时,SqlSession对象及其内部的Executor对象还有PerpetualCache对象也一并释放掉。spa
b、若是SqlSession调用了close()方法,会释放掉一级缓存PerpetualCache对象,一级缓存将不可用。对象