亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

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

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

一級(jí)緩存(Session級(jí)別)

一級(jí)緩存是基于 SQL 會(huì)話(SqlSession)的,它是默認(rèn)開(kāi)啟的。一級(jí)緩存的生命周期與 SQL 會(huì)話一致,當(dāng)會(huì)話結(jié)束時(shí),緩存也隨之消失。這意味著,在同一個(gè) SQL 會(huì)話中,對(duì)于相同的查詢請(qǐng)求,第一次會(huì)從數(shù)據(jù)庫(kù)中獲取數(shù)據(jù),并緩存結(jié)果;之后相同的查詢請(qǐng)求將直接從緩存中獲取數(shù)據(jù),不會(huì)再去訪問(wèn)數(shù)據(jù)庫(kù)。

try (SqlSession session = sqlSessionFactory.openSession()) {
    BlogMapper mapper = session.getMapper(BlogMapper.class);
    
    // 第一次查詢,數(shù)據(jù)來(lái)自數(shù)據(jù)庫(kù)
    Blog blog1 = mapper.selectBlogById(1);
    // 第二次查詢,相同的會(huì)話中,數(shù)據(jù)來(lái)自一級(jí)緩存
    Blog blog2 = mapper.selectBlogById(1);
}

一級(jí)緩存主要是利用了一個(gè) Map 來(lái)存儲(chǔ)緩存數(shù)據(jù),關(guān)鍵代碼在 DefaultSqlSession 類(lèi)中的 selectList 方法里,它使用了 Executor 的 query 方法來(lái)實(shí)現(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 類(lèi)的 query 方法中實(shí)現(xiàn)了一級(jí)緩存的邏輯:

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);
}

二級(jí)緩存(全局級(jí)別)

二級(jí)緩存是跨 SQL 會(huì)話的,它基于 namespace 級(jí)別。開(kāi)啟二級(jí)緩存后,數(shù)據(jù)會(huì)存儲(chǔ)在全局作用域內(nèi),這意味著,即使 SQL 會(huì)話關(guān)閉,緩存數(shù)據(jù)仍然可用,可以被其他 SQL 會(huì)話復(fù)用。

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

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

在映射文件中使用二級(jí)緩存:

<!-- 在 Mapper.xml 中開(kāi)啟二級(jí)緩存 -->
<cache eviction="FIFO" flushInterval="60000" size="512" readOnly="true"/>

二級(jí)緩存的關(guān)鍵實(shí)現(xiàn)在 CachingExecutor 類(lèi):

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é)

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

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

相關(guān)文章

  • Java中生成隨機(jī)數(shù)的4種方式與區(qū)別詳解

    Java中生成隨機(jī)數(shù)的4種方式與區(qū)別詳解

    生成隨機(jī)數(shù)是我們?nèi)粘i_(kāi)發(fā)經(jīng)常會(huì)遇到的一個(gè)功能,這篇文章主要給大家介紹了關(guān)于Java中生成隨機(jī)數(shù)的4種方式與區(qū)別、應(yīng)用場(chǎng)景的相關(guān)資料,4個(gè)方式分別是Random、ThreadLocalRandom、SecureRandom以及Math,需要的朋友可以參考下
    2021-06-06
  • 基于SpringBoot整合SSMP案例(開(kāi)啟日志與分頁(yè)查詢條件查詢功能實(shí)現(xiàn))

    基于SpringBoot整合SSMP案例(開(kāi)啟日志與分頁(yè)查詢條件查詢功能實(shí)現(xiàn))

    這篇文章主要介紹了基于SpringBoot整合SSMP案例(開(kāi)啟日志與分頁(yè)查詢條件查詢功能實(shí)現(xiàn)),本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋參考下吧
    2023-11-11
  • 詳解Java MD5二次加密的應(yīng)用

    詳解Java MD5二次加密的應(yīng)用

    MD5的全稱是message-digest algorithm 5 信息-摘要算法。這篇文章主要為大家詳細(xì)介紹了Java中MD5二次加密的應(yīng)用,感興趣的小伙伴可以了解一下
    2023-02-02
  • Mybatis開(kāi)發(fā)環(huán)境搭建實(shí)現(xiàn)數(shù)據(jù)的增刪改查功能

    Mybatis開(kāi)發(fā)環(huán)境搭建實(shí)現(xiàn)數(shù)據(jù)的增刪改查功能

    這篇文章主要介紹了 Mybatis開(kāi)發(fā)環(huán)境搭建實(shí)現(xiàn)數(shù)據(jù)的增刪改查功能,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2017-03-03
  • 基于JDBC訪問(wèn)MySql公共方法實(shí)例解析

    基于JDBC訪問(wèn)MySql公共方法實(shí)例解析

    這篇文章主要介紹了基于JDBC訪問(wèn)MySql公共方法實(shí)例解析,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-10-10
  • Spring AspectJ 實(shí)現(xiàn)AOP的方法你了解嗎

    Spring AspectJ 實(shí)現(xiàn)AOP的方法你了解嗎

    這篇文章主要為大家介紹了Spring AspectJ 實(shí)現(xiàn)AOP的方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下,希望能夠給你帶來(lái)幫助
    2022-01-01
  • Spring Boot 的java -jar命令啟動(dòng)原理詳解

    Spring Boot 的java -jar命令啟動(dòng)原理詳解

    這篇文章主要介紹了Spring Boot 的java -jar命令啟動(dòng)原理詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-01-01
  • Spring IOC基于注解啟動(dòng)示例詳析

    Spring IOC基于注解啟動(dòng)示例詳析

    這篇文章主要給大家介紹了Spring IOC基于注解啟動(dòng)的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • 關(guān)于Feign調(diào)用服務(wù)Headers傳參問(wèn)題

    關(guān)于Feign調(diào)用服務(wù)Headers傳參問(wèn)題

    這篇文章主要介紹了關(guān)于Feign調(diào)用服務(wù)Headers傳參問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • Spring Web MVC框架學(xué)習(xí)之配置Spring Web MVC

    Spring Web MVC框架學(xué)習(xí)之配置Spring Web MVC

    這一篇文章講的是Spring Web MVC各部分的配置方法,包括Java代碼配置和XML文件配置以及MVC命名空間的使用方法。
    2017-03-03

最新評(píng)論