MyBatis的缓存机制主要有两种:
一级缓存:也称本地缓存,是MyBatis默认开启的缓存机制。一级缓存是在同一个SqlSession中有效,当执行相同的SQL语句时,如果参数相同且查询条件相同,则会从缓存中获取结果,而不会再次发送SQL语句到数据库。一级缓存是基于对象引用的缓存,当SqlSession关闭后,缓存也会被清空。
二级缓存:也称全局缓存,是在多个SqlSession之间共享的缓存机制。二级缓存可以跨SqlSession共享数据,可以有效地减少数据库的访问次数。默认情况下,二级缓存是关闭的,需要手动配置开启。开启二级缓存后,MyBatis会将查询结果放入缓存中,下次执行相同的SQL语句时,会先从缓存中获取结果,如果缓存中存在,则直接返回结果,否则发送SQL语句到数据库并将结果放入缓存中。
需要注意的是,MyBatis的缓存机制对于更新操作是敏感的,当执行insert、update、delete等更新操作时,会清空对应的缓存数据,保证缓存的一致性。另外,MyBatis的缓存机制是基于namespace级别的,即同一个namespace下的SQL语句共享同一个缓存。如果需要使用二级缓存,需要在Mapper XML文件中配置