MyBatis的一级缓存和二级缓存之间存在以下主要区别:
- 缓存级别与作用域:
- 一级缓存:也称为SqlSession级别的缓存,与数据库会话(SqlSession对象)绑定,并且默认开启。一级缓存的作用域仅限于同一个SqlSession。在同一个SqlSession中,当执行相同的SQL查询时,第一次会查询数据库并将结果存储在缓存中,第二次则直接从缓存中获取结果,无需再次查询数据库。但是,如果在两次查询之间执行了增删改操作,则SqlSession的缓存会被清空。
- 二级缓存:也称为mapper级别的缓存,是全局的缓存,可以被多个SqlSession共享。二级缓存默认是关闭的,需要手动配置才能开启。当开启二级缓存后,同一个namespace下的所有操作语句都会影响到同一个Cache,即二级缓存被多个SqlSession共享。
- 缓存数据与数据共享:
- 一级缓存:其缓存数据只会在同一次SqlSession会话中有效。当SqlSession结束或执行了增删改操作后,一级缓存中的数据将被清空。
- 二级缓存:当开启后,同一个namespace下的所有操作语句都影响着同一个Cache。这意味着,不同的SqlSession可以共享二级缓存中的数据。
- 缓存查询流程:
- 在开启二级缓存的情况下,数据的查询执行流程通常是先查询二级缓存,如果未找到则查询一级缓存,如果一级缓存中也未找到,则最终查询数据库。
总的来说,MyBatis的一级缓存和二级缓存各有其特点和用途。一级缓存主要关注于单个SqlSession的查询效率,而二级缓存则更关注于全局的查询效率和数据共享。根据具体的业务需求和应用场景,可以选择开启或关闭相应的缓存级别。