mybatis一级缓存和二级缓存的作用和区别
时间: 2023-07-01 08:19:41 浏览: 192
Mybatis提供了两级缓存:
- 一级缓存(本地缓存):Mybatis默认开启的,其作用域为SqlSession级别,即在同一个SqlSession中执行相同的查询语句,第一次查询结果会被缓存下来,再次查询相同语句时直接从缓存中获取结果,避免了重复查询数据库,提高了效率。
- 二级缓存(全局缓存):其作用域为整个应用程序,多个SqlSession之间可以共享缓存数据,需要手动开启。当SqlSession执行查询时,查询的数据会被缓存到二级缓存中,再次执行相同的查询时,直接从缓存中获取数据,避免了重复查询数据库,提高了效率。
二级缓存需要注意以下几点:
- 对于同一条SQL语句,如果执行过程中有任何的update、insert、delete操作,那么缓存会被清空,下次查询会重新执行SQL语句并缓存结果。
- 对于同一条SQL语句,如果有多个参数,那么不同参数对应的查询结果也会被缓存到不同的缓存中,需要注意查询参数的一致性。
- 二级缓存中存储的是对象的引用地址,而不是对象本身,因此需要保证缓存中的对象不被修改。
一级缓存和二级缓存的区别:
- 一级缓存是SqlSession级别的缓存,生命周期比较短,只在SqlSession内有效,而二级缓存是全局的缓存,生命周期比较长,多个SqlSession可以共享缓存数据。
- 一级缓存默认开启,二级缓存需要手动开启。
- 一级缓存是基于对象引用的缓存,与数据库同步,而二级缓存是基于数据的缓存,与数据库异步。
相关问题
MyBatis 一级缓存和二级缓存的区别
MyBatis一级缓存和二级缓存的区别如下:
1. 一级缓存是SqlSession级别的缓存,二级缓存是Mapper级别的缓存。
2. 一级缓存默认开启,无法关闭,二级缓存默认关闭,可以手动开启。
3. 一级缓存的作用域是同一个SqlSession,二级缓存的作用域是同一个Mapper。
4. 一级缓存的生命周期是和SqlSession一样长,二级缓存的生命周期是和应用程序一样长。
5. 一级缓存的更新机制是基于时间戳和刷新策略,二级缓存的更新机制是基于触发器和事务提交。
下面是一个使用MyBatis的例子,演示了如何开启和关闭二级缓存:
```xml
<!-- 开启二级缓存 -->
<settings>
<setting name="cacheEnabled" value="true"/>
</settings>
<!-- 关闭二级缓存 -->
<settings>
<setting name="cacheEnabled" value="false"/>
</settings>
```
mybatis一级缓存和二级缓存代码的区别
MyBatis的一级缓存(First Level Cache)和二级缓存(Second Level Cache)都是为了提高数据库查询性能而设计的机制。
**一级缓存**:这是默认启用的,在每个SqlSession实例中,对所有的Statement或PreparedStatement进行了缓存。当多次执行相同的查询时,结果会直接从一级缓存获取,而不是每次都去数据库。一级缓存在事务结束时会被清除,如果一个事务涉及到了多个SQL查询,它们可能会共享这个缓存。
**二级缓存**:它是一个更高级别的缓存,通常是在全局应用服务器级别或集群环境下的分布式缓存。MyBatis提供了`<cache>`标签配置二级缓存,可以跨SqlSession,即多个线程甚至多个应用服务器实例共享数据。设置好缓存的key、生命周期等属性后,对于那些标记了缓存注解的实体对象,如果从数据库加载后放入二级缓存,并且下次查询到相同的key,也会直接返回缓存的数据。
以下是基本代码示例:
```xml
<mapper namespace="...">
<cache eviction="LRU" size="100" />
<!-- ... -->
<select id="queryUser" resultType="User">
SELECT * FROM user WHERE id = #{id}
</select>
</mapper>
// 代码示例
User user = sqlSession.selectOne("queryUser", 1);
// 如果第一次查询结果进入了一级和二级缓存,第二次再查询同样的ID就会直接从缓存中读取
```
阅读全文