欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MyBatis中一級緩存和二級緩存的區(qū)別

 更新時間:2024年07月05日 09:36:18   作者:辭暮爾爾-煙火年年  
MyBatis提供了兩級緩存機制,一級緩存和二級緩存,本文主要介紹了MyBatis中一級緩存和二級緩存的區(qū)別,具有一定的參考價值,感興趣的可以了解一下

MyBatis 提供了兩級緩存機制:一級緩存(Session級別)和二級緩存(全局級別),以提高應(yīng)用的性能通過減少數(shù)據(jù)庫的查詢次數(shù)。

一級緩存(Session級別)

一級緩存是基于 SQL 會話(SqlSession)的,它是默認(rèn)開啟的。一級緩存的生命周期與 SQL 會話一致,當(dāng)會話結(jié)束時,緩存也隨之消失。這意味著,在同一個 SQL 會話中,對于相同的查詢請求,第一次會從數(shù)據(jù)庫中獲取數(shù)據(jù),并緩存結(jié)果;之后相同的查詢請求將直接從緩存中獲取數(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ù),關(guān)鍵代碼在 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ù)會存儲在全局作用域內(nèi),這意味著,即使 SQL 會話關(guān)閉,緩存數(shù)據(jù)仍然可用,可以被其他 SQL 會話復(fù)用。

要啟用二級緩存,需要在 MyBatis 配置文件中添加相應(yīng)的配置,并在映射文件中明確指定哪些映射器使用二級緩存。

<!-- 在 mybatis-config.xml 中啟用全局二級緩存 -->
<configuration>
    <settings>
        <setting name="cacheEnabled" value="true"/>
    </settings>
</configuration>

在映射文件中使用二級緩存:

<!-- 在 Mapper.xml 中開啟二級緩存 -->
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>

二級緩存的關(guān)鍵實現(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ū)別總結(jié)

  • 作用范圍:一級緩存是基于 SqlSession 的,其生命周期也隨之綁定;而二級緩存是基于 Mapper 的 namespace,對整個應(yīng)用有效。
  • 生命周期:一級緩存隨著 SQL 會話的結(jié)束而失效,二級緩存則可以跨會話使用。
  • 可自定義性:二級緩存提供了更多的自定義設(shè)置,例如失效策略、大小限制等,通過在 Mapper.xml 中配置 <cache> 標(biāo)簽來實現(xiàn)。
  • 數(shù)據(jù)安全:二級緩存由于是跨會話的,使用時需要更加注意數(shù)據(jù)的一致性問題。在使用二級緩

到此這篇關(guān)于MyBatis中一級緩存和二級緩存的區(qū)別的文章就介紹到這了,更多相關(guān)MyBatis 一級緩存和二級緩存內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家! 

相關(guān)文章

  • SpringBoot實現(xiàn)分布式驗證碼登錄方案小結(jié)

    SpringBoot實現(xiàn)分布式驗證碼登錄方案小結(jié)

    驗證碼登錄作為一種有效的防護(hù)手段,可以防止惡意gongji、暴力pojie等,本文主要介紹了SpringBoot實現(xiàn)分布式驗證碼登錄方案小結(jié),具有一定的參考價值,感興趣的可以了解一下
    2024-12-12
  • 使用Springboot實現(xiàn)OAuth服務(wù)的示例詳解

    使用Springboot實現(xiàn)OAuth服務(wù)的示例詳解

    OAuth(Open Authorization)是一個開放標(biāo)準(zhǔn),用于授權(quán)第三方應(yīng)用程序訪問用戶資源,而不需要共享用戶憑證。本文主要介紹了如何使用Springboot實現(xiàn)一個OAuth服務(wù),需要的可以參考一下
    2023-05-05
  • Idea jdk版本問題解決方案

    Idea jdk版本問題解決方案

    這篇文章主要介紹了Idea jdk版本問題解決方案,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-07-07
  • java中Servlet程序下載文件實例詳解

    java中Servlet程序下載文件實例詳解

    在本篇文章里小編給大家整理的是一篇關(guān)于java中Servlet程序下載文件實例內(nèi)容,有興趣的朋友們可以學(xué)習(xí)參考下。
    2021-02-02
  • Java多線程同步工具類CountDownLatch詳解

    Java多線程同步工具類CountDownLatch詳解

    這篇文章主要介紹了Java多線程同步工具類CountDownLatch詳解,CountDownLatch是一個多線程同步工具類,在多線程環(huán)境中它允許多個線程處于等待狀態(tài),直到前面的線程執(zhí)行結(jié)束
    2022-06-06
  • Java開發(fā)過程中關(guān)于異常處理的詳解

    Java開發(fā)過程中關(guān)于異常處理的詳解

    異常是程序中的一些錯誤,但不是所有錯誤都是異常,且錯誤有時候是可以避免的。比如說,你的代碼少一個分號,那運行出來結(jié)果是提示是錯誤 java.lang.Error;如果你用System.out.println(11/0),那么你是因為你用0做了除數(shù),會拋出 java.lang.ArithmeticException 的異常
    2021-10-10
  • 通過反射注解批量插入數(shù)據(jù)到DB的實現(xiàn)方法

    通過反射注解批量插入數(shù)據(jù)到DB的實現(xiàn)方法

    今天小編就為大家分享一篇關(guān)于通過反射注解批量插入數(shù)據(jù)到DB的實現(xiàn)方法,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2019-03-03
  • Java中利用BitMap位圖實現(xiàn)海量級數(shù)據(jù)去重

    Java中利用BitMap位圖實現(xiàn)海量級數(shù)據(jù)去重

    有許多方法可以用來去重,比如使用列表、集合等等,但這些方法通常只適用于一般情況,然而,當(dāng)涉及到大量數(shù)據(jù)去重時,常見的 Java Set、List,甚至是 Java 8 的新特性 Stream 流等方式就顯得不太合適了,本文給大家介紹了Java中利用BitMap位圖實現(xiàn)海量級數(shù)據(jù)去重
    2024-04-04
  • Jdbc連接數(shù)據(jù)庫基本步驟詳解

    Jdbc連接數(shù)據(jù)庫基本步驟詳解

    這篇文章主要為大家詳細(xì)介紹了Jdbc連接數(shù)據(jù)庫的基本步驟,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-10-10
  • Java?Web實戰(zhàn)之使用三層架構(gòu)與Servlet構(gòu)建登錄注冊模塊

    Java?Web實戰(zhàn)之使用三層架構(gòu)與Servlet構(gòu)建登錄注冊模塊

    這篇文章介紹了如何使用三層架構(gòu)(View,?Service,?DAO)和JDBCTemplate技術(shù)在JavaWeb環(huán)境下實現(xiàn)登錄和注冊功能,詳細(xì)說明了構(gòu)建項目的步驟,包括創(chuàng)建數(shù)據(jù)庫表、實體類、DAO層、Service層、Servlet處理及頁面設(shè)計,需要的朋友可以參考下
    2024-10-10

最新評論