MyBatis是一种持久化框架,它提供了一级和二级缓存来提高数据库访问性能。
一级缓存是MyBatis默认开启的缓存机制,它是基于线程的缓存,每个SqlSession都有一个独立的一级缓存。当SqlSession执行查询操作时,查询结果会被存储在一级缓存中。当再次执行相同的查询时,MyBatis会先检查一级缓存中是否存在相同的查询结果,如果存在,则直接从缓存中获取查询结果,而不再去数据库中执行查询操作。一级缓存的生命周期是与SqlSession的生命周期相同,当SqlSession被关闭或提交事务时,一级缓存也会被清空。
二级缓存是基于Mapper级别的缓存,它可以被多个SqlSession共享。当多个SqlSession执行相同的查询时,如果查询结果在二级缓存中存在,则所有的SqlSession都可以直接从缓存中获取查询结果,而不再去数据库中执行查询操作。二级缓存的生命周期是与应用程序的生命周期相同,当应用程序重新启动或重新部署时,二级缓存会被清空。
要启用二级缓存,需要在MyBatis的配置文件中配置元素。可以配置以下属性来控制二级缓存的行为:
- eviction:缓存的淘汰策略,默认为LRU(最近最少使用),还可以选择FIFO(先进先出)和SOFT(软引用)。
- flushInterval:缓存刷新间隔时间,单位为毫秒,默认为不刷新。
- readOnly:指定缓存是否只读,默认为false。
- size:指定缓存的最大容量,默认为1024。
需要注意的是,二级缓存只对查询操作有效,对于更新操作(insert、update、delete),MyBatis会自动清空相关的缓存。
另外,对于一些特殊情况,可以使用@CacheNamespace注解来配置Mapper级别的缓存,或者使用@Cacheable和@CacheEvict注解来对特定的方法进行缓存配置。这些注解可以更加灵活地控制缓存的行为。