mybatis一级缓存和二级缓存的作用和区别
时间: 2023-07-01 21:19:41 浏览: 199
Mybatis提供了两级缓存:
- 一级缓存(本地缓存):Mybatis默认开启的,其作用域为SqlSession级别,即在同一个SqlSession中执行相同的查询语句,第一次查询结果会被缓存下来,再次查询相同语句时直接从缓存中获取结果,避免了重复查询数据库,提高了效率。
- 二级缓存(全局缓存):其作用域为整个应用程序,多个SqlSession之间可以共享缓存数据,需要手动开启。当SqlSession执行查询时,查询的数据会被缓存到二级缓存中,再次执行相同的查询时,直接从缓存中获取数据,避免了重复查询数据库,提高了效率。
二级缓存需要注意以下几点:
- 对于同一条SQL语句,如果执行过程中有任何的update、insert、delete操作,那么缓存会被清空,下次查询会重新执行SQL语句并缓存结果。
- 对于同一条SQL语句,如果有多个参数,那么不同参数对应的查询结果也会被缓存到不同的缓存中,需要注意查询参数的一致性。
- 二级缓存中存储的是对象的引用地址,而不是对象本身,因此需要保证缓存中的对象不被修改。
一级缓存和二级缓存的区别:
- 一级缓存是SqlSession级别的缓存,生命周期比较短,只在SqlSession内有效,而二级缓存是全局的缓存,生命周期比较长,多个SqlSession可以共享缓存数据。
- 一级缓存默认开启,二级缓存需要手动开启。
- 一级缓存是基于对象引用的缓存,与数据库同步,而二级缓存是基于数据的缓存,与数据库异步。
相关问题
mybatis一级缓存和二级缓存区别
MyBatis一级缓存和二级缓存区别如下:
一级缓存是SqlSession级别的缓存,当我们发起一次查询时,MyBatis会先到SqlSession缓存中查询是否有这个结果,如果有,直接返回缓存结果,如果没有,就去数据库中查询结果,查询完结果后,将结果放入SqlSession缓存中。
二级缓存是Mapper级别的缓存,当我们发起一次查询时,MyBatis会先到Mapper缓存中查询是否有这个结果,如果有,直接返回缓存结果,如果没有,就去数据库中查询结果,查询完结果后,将结果放入Mapper缓存中。二级缓存通常会开启,但是并不是所有的Mapper都需要开启二级缓存,需要根据具体情况进行配置。
mybatis一级缓存和二级缓存的区别
Mybatis的一级缓存是指在同一个SqlSession中,如果执行了相同的SQL语句,那么第二次及以后的查询会直接从内存中获取缓存的结果,而不需要再次发送SQL到数据库中执行。
而Mybatis的二级缓存则是指在多个SqlSession之间共享缓存,通过将查询结果存储在Cache中,多个SqlSession可以从Cache中获取相同的查询结果,从而避免了重复查询数据库的开销。
简单来说,一级缓存是SqlSession级别的缓存,二级缓存是Mapper级别的缓存。一级缓存只在当前SqlSession中有效,而二级缓存则可以被多个SqlSession共享。
阅读全文
相关推荐
![-](https://img-home.csdnimg.cn/images/20241231044930.png)
![-](https://img-home.csdnimg.cn/images/20241231044930.png)
![-](https://img-home.csdnimg.cn/images/20241231044930.png)
![rar](https://img-home.csdnimg.cn/images/20241231044955.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)
![](https://csdnimg.cn/download_wenku/file_type_ask_c1.png)