MyBatis中一級緩存和二級緩存的區(qū)別
MyBatis 提供了兩級緩存機制:一級緩存(Session級別)和二級緩存(全局級別),以提高應用的性能通過減少數(shù)據(jù)庫的查詢次數(shù)。
一級緩存(Session級別)
一級緩存是基于 SQL 會話(SqlSession
)的,它是默認開啟的。一級緩存的生命周期與 SQL 會話一致,當會話結束時,緩存也隨之消失。這意味著,在同一個 SQL 會話中,對于相同的查詢請求,第一次會從數(shù)據(jù)庫中獲取數(shù)據(jù),并緩存結果;之后相同的查詢請求將直接從緩存中獲取數(shù)據(jù),不會再去訪問數(shù)據(jù)庫。
try (SqlSession session = sqlSessionFactory.openSession()) { BlogMapper mapper = session.getMapper(BlogMapper.class); // 第一次查詢,數(shù)據(jù)來自數(shù)據(jù)庫 Blog blog1 = mapper.selectBlogById(1); // 第二次查詢,相同的會話中,數(shù)據(jù)來自一級緩存 Blog blog2 = mapper.selectBlogById(1); }
一級緩存主要是利用了一個 Map
來存儲緩存數(shù)據(jù),關鍵代碼在 DefaultSqlSession
類中的 selectList
方法里,它使用了 Executor
的 query
方法來實現(xiàn)。
public <E> List<E> selectList(String statement, Object parameter, RowBounds rowBounds) { try { MappedStatement ms = configuration.getMappedStatement(statement); return executor.query(ms, wrapCollection(parameter), rowBounds, Executor.NO_RESULT_HANDLER); } catch (Exception e) { throw ExceptionFactory.wrapException("Error querying database. Cause: " + e, e); } finally { ErrorContext.instance().reset(); } }
在 CachingExecutor
類的 query
方法中實現(xiàn)了一級緩存的邏輯:
public <E> List<E> query(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler) throws SQLException { BoundSql boundSql = ms.getBoundSql(parameter); CacheKey key = createCacheKey(ms, parameter, rowBounds, boundSql); return query(ms, parameter, rowBounds, resultHandler, key, boundSql); }
二級緩存(全局級別)
二級緩存是跨 SQL 會話的,它基于 namespace 級別。開啟二級緩存后,數(shù)據(jù)會存儲在全局作用域內,這意味著,即使 SQL 會話關閉,緩存數(shù)據(jù)仍然可用,可以被其他 SQL 會話復用。
要啟用二級緩存,需要在 MyBatis 配置文件中添加相應的配置,并在映射文件中明確指定哪些映射器使用二級緩存。
<!-- 在 mybatis-config.xml 中啟用全局二級緩存 --> <configuration> <settings> <setting name="cacheEnabled" value="true"/> </settings> </configuration>
在映射文件中使用二級緩存:
<!-- 在 Mapper.xml 中開啟二級緩存 --> <cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>
二級緩存的關鍵實現(xiàn)在 CachingExecutor
類:
public <E> List<E> query(MappedStatement ms, Object parameter, RowBounds rowBounds, ResultHandler resultHandler, CacheKey key, BoundSql boundSql) throws SQLException { Cache cache = ms.getCache(); if (cache != null) { flushCacheIfRequired(ms); if (ms.isUseCache() && resultHandler == null) { ensureNoOutParams(ms, boundSql); @SuppressWarnings("unchecked") List<E> list = (List<E>) tcm.getObject(cache, key); if (list == null) { list = delegate.query(ms, parameter, rowBounds, resultHandler, key, boundSql); tcm.putObject(cache, key, list); // issue #578 and #116 } return list; } } return delegate.query(ms, parameter, rowBounds, resultHandler, key, boundSql); }
區(qū)別總結
- 作用范圍:一級緩存是基于
SqlSession
的,其生命周期也隨之綁定;而二級緩存是基于 Mapper 的 namespace,對整個應用有效。 - 生命周期:一級緩存隨著 SQL 會話的結束而失效,二級緩存則可以跨會話使用。
- 可自定義性:二級緩存提供了更多的自定義設置,例如失效策略、大小限制等,通過在 Mapper.xml 中配置
<cache>
標簽來實現(xiàn)。 - 數(shù)據(jù)安全:二級緩存由于是跨會話的,使用時需要更加注意數(shù)據(jù)的一致性問題。在使用二級緩
到此這篇關于MyBatis中一級緩存和二級緩存的區(qū)別的文章就介紹到這了,更多相關MyBatis 一級緩存和二級緩存內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
基于SpringBoot整合SSMP案例(開啟日志與分頁查詢條件查詢功能實現(xiàn))
這篇文章主要介紹了基于SpringBoot整合SSMP案例(開啟日志與分頁查詢條件查詢功能實現(xiàn)),本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋參考下吧2023-11-11Mybatis開發(fā)環(huán)境搭建實現(xiàn)數(shù)據(jù)的增刪改查功能
這篇文章主要介紹了 Mybatis開發(fā)環(huán)境搭建實現(xiàn)數(shù)據(jù)的增刪改查功能,非常不錯,具有參考借鑒價值,需要的朋友可以參考下2017-03-03Spring AspectJ 實現(xiàn)AOP的方法你了解嗎
這篇文章主要為大家介紹了Spring AspectJ 實現(xiàn)AOP的方法,具有一定的參考價值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來幫助2022-01-01Spring Boot 的java -jar命令啟動原理詳解
這篇文章主要介紹了Spring Boot 的java -jar命令啟動原理詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2020-01-01Spring Web MVC框架學習之配置Spring Web MVC
這一篇文章講的是Spring Web MVC各部分的配置方法,包括Java代碼配置和XML文件配置以及MVC命名空間的使用方法。2017-03-03