1.一级缓存
同一个事务中,第二次及以后相同的sql语句会直接读缓存,不会执行。
关闭一级缓存:
2.二级缓存(默认关闭)
第一次查询后就在mapper.xml里的namespace里添加缓存。
mapper不一样他们的namespace就不一样,即使两个查询的sql一样但mapper不一样也要再查询一次。
(1)开启方式
先实现接口将类序列化(将缓存的数据保存,后续需要将缓存还原成这个类。需要把数据保存,下次再还原时,需要用到序列化。对类做传输的场景也会使用)
后在xml中添加<cache><cache>
(2)失效
对namespace有增删改的时候,缓存就会失效
(3)缺点
有两个节点的时候,如果这两个节点都执行了查询语句,有缓存了。但这时候有一条删除语句要执行,只会走到其中一个节点上,导致另一个节点缓存仍然存在,数据可能有误的问题。
二级缓存很少使用。