一级缓存:
范围:同一个SqlSession对象
过程:
1:第一次查询张三会经历两个步骤:
(1)向数据库发送SQL语句查询张三
(2)并将张三放入一级缓存中
2:第N次查询张三只经历一个步骤
(1)直接从一级缓存中获取张三
Mybatis默认开启 一级缓存,如果用同样的SqlSession对象查询相同的数据时,则只会在第一次查询时向数据库发送SQL语句,并将查询的结果放在SQLSESSION中(作为缓存),后续再次查询该同样的对象时,则直接从缓存中查询该对象即可(省略了数据库的访问,提高性能)
二级缓存:
范围:同一个namespace
过程:
1.两个相同的SqlSession1产生的xxxMapper对象查询李四
(1)向数据库发送SQL语句查询李四
(2)并将李四放入一级缓存中
(3)第N次查询则直接从一级缓存中获取
2.另一个SqlSession2产生的xxxMapper对象查询李四
(1)如果二级缓存中没有李四,则此次查询需要重新向数据库发送SQL语句
(2)虽然一级缓存中有李四,但是是由SqlSession1共享的,SqlSession2是不共享的,所以SqlSession2需要重新向数据库中发送SQL语句
(3)如果SqlSession查询完李四后,执行了close()方法,则将李四放入了二级缓存中,又因为SqlSession1和SqlSession2的根源是同一个namespace,所以共享二级缓存,所以现在查询李四,则直接从二级缓存中获取,不需要向数据库发送SQL语句了