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

MyBatis執(zhí)行批處理操作的實現(xiàn)示例

 更新時間:2024年07月05日 10:34:45   作者:辭暮爾爾-煙火年年  
在MyBatis中,批處理操作是一種高效執(zhí)行多條語句的方式,下面就來介紹一下MyBatis執(zhí)行批處理操作的實現(xiàn)示例,具有一定的參考價值,感興趣的可以了解一下

在MyBatis中,批處理操作是一種高效執(zhí)行多條語句的方式,特別是當(dāng)你需要在一個事務(wù)中插入、更新或刪除多條記錄時。批處理可以顯著減少與數(shù)據(jù)庫的交互次數(shù),從而提高性能。

執(zhí)行批處理的基本步驟

  • 開啟批處理模式:在獲取SqlSession時,需要指定執(zhí)行器(Executor)類型為ExecutorType.BATCH。
  • 執(zhí)行SQL語句:執(zhí)行需要批處理的SQL語句,此時語句并不會立即執(zhí)行,而是被添加到批處理隊列中。
  • 提交事務(wù):調(diào)用SqlSession.commit()方法,此時MyBatis會將批處理隊列中的語句一次性發(fā)送給數(shù)據(jù)庫執(zhí)行。
  • 處理批處理結(jié)果:提交事務(wù)后,可以通過批處理結(jié)果進行后續(xù)處理。

示例代碼

try (SqlSession sqlSession = sqlSessionFactory.openSession(ExecutorType.BATCH)) {
    YourMapper mapper = sqlSession.getMapper(YourMapper.class);
    for (YourData data : dataList) {
        // 根據(jù)需要調(diào)用insert, update或delete方法
        mapper.insertOrUpdate(data);
    }
    sqlSession.commit();
    // 可以獲取批處理結(jié)果,處理特定邏輯
}

深入源碼解析

在MyBatis中,批處理的核心是BatchExecutor,這是Executor的一個實現(xiàn)。在開啟批處理模式時,MyBatis會使用BatchExecutor來處理SQL會話。

BatchExecutor的關(guān)鍵方法

  • doUpdate: 當(dāng)執(zhí)行insert、update、delete方法時,BatchExecutor會將這些操作存儲在內(nèi)部的批處理隊列中,而不是立即執(zhí)行它們。
  • doFlushStatements: 當(dāng)調(diào)用commitflushStatements時,BatchExecutor會執(zhí)行批處理隊列中的所有SQL語句。這些操作是通過JDBC的PreparedStatement.executeBatch()方法執(zhí)行的。
@Override
public int doUpdate(MappedStatement ms, Object parameter) throws SQLException {
    final Configuration configuration = ms.getConfiguration();
    final StatementHandler handler = configuration.newStatementHandler(this, ms, parameter, RowBounds.DEFAULT, null, null);
    final BoundSql boundSql = handler.getBoundSql();
    final String sql = boundSql.getSql();
    final Statement stmt;
    if (sql.equals(currentSql) && ms.equals(currentStatement)) {
        int last = statementList.size() - 1;
        stmt = statementList.get(last);
        applyTransactionTimeout(stmt);
        handler.parameterize(stmt);//fix Issues 322
    } else {
        Connection connection = getConnection(ms.getStatementLog());
        stmt = handler.prepare(connection, transaction.getTimeout());
        handler.parameterize(stmt);    //fix Issues 322
        currentSql = sql;
        currentStatement = ms;
        statementList.add(stmt);
        batchResultList.add(new BatchResult(ms, sql, parameter));
    }
    handler.batch(stmt);
    return BATCH_UPDATE_RETURN_VALUE;
}

執(zhí)行批處理

當(dāng)調(diào)用commitflushStatements時,BatchExecutor.doFlushStatements會被觸發(fā),它負責(zé)實際執(zhí)行批處理操作。

@Override
public List<BatchResult> doFlushStatements(boolean isRollback) throws SQLException {
    try {
        if (isRollback) {
            return Collections.emptyList();
        }

        List<BatchResult> results = new ArrayList<>();
        if (statementList.size() > 0) {
            for (int i = 0, n = statementList.size(); i < n; i++) {
                Statement stmt = statementList.get(i);
                BatchResult batchResult = batchResultList.get(i);
                try {
                    batchResult.setUpdateCounts(stmt.executeBatch());
                    MappedStatement ms = batchResult.getMappedStatement();
                    List<Object> parameterObjects = batchResult.getParameterObjects();
                    KeyGenerator keyGenerator = ms.getKeyGenerator();
                    if (Jdbc3KeyGenerator.class.equals(keyGenerator.getClass())) {
                        Jdbc3KeyGenerator jdbc3KeyGenerator = (Jdbc3KeyGenerator) keyGenerator;
                        jdbc3KeyGenerator.processBatch(ms, stmt, parameterObjects);
                    } else if (!NoKeyGenerator.class.equals(keyGenerator.getClass())) { //issue #141
                        for (Object parameter : parameterObjects) {
                            keyGenerator.processAfter(this, ms, stmt, parameter);
                        }
                    }
                } finally {
                    closeStatement(stmt);
                }
            }
        }
        return results;
    } finally {
        for (Statement stmt : statementList) {
            closeStatement(stmt);
        }
        currentSql = null;
        statementList.clear();
        batchResultList.clear();
    }
}

小結(jié)

MyBatis的批處理通過BatchExecutor實現(xiàn),它通過將SQL語句收集到批處理隊列中,然后在適當(dāng)?shù)臅r候(如調(diào)用commit)一次性執(zhí)行,以提高性能。正確使用批處理可以在執(zhí)行大量類似操作時大幅度減少應(yīng)用與數(shù)據(jù)庫的交互次數(shù),優(yōu)化應(yīng)用性能。不過,要注意批處理可能會對事務(wù)管理、錯誤處理等方面帶來額外的復(fù)雜性,使用時需要特別留意。

到此這篇關(guān)于MyBatis執(zhí)行批處理操作的實現(xiàn)示例的文章就介紹到這了,更多相關(guān)MyBatis 批處理操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • java使用httpclient發(fā)送post請求示例

    java使用httpclient發(fā)送post請求示例

    這篇文章主要介紹了java使用httpclient發(fā)送post請求示例,依賴JSON、HTTPClient等jar包,需要的朋友可以參考下
    2014-02-02
  • 解決Jackson反序列化map,set等復(fù)雜類型問題

    解決Jackson反序列化map,set等復(fù)雜類型問題

    這篇文章主要介紹了解決Jackson反序列化map,set等復(fù)雜類型問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2020-09-09
  • Java8新特性之Lambda表達式的使用

    Java8新特性之Lambda表達式的使用

    這篇文章主要介紹了Java8新特性之Lambda表達式的使用,文中有非常詳細的代碼示例,對正在學(xué)習(xí)java的小伙伴們有非常好的幫助,需要的朋友可以參考下
    2021-04-04
  • 基于Integer值判斷是否相等的問題

    基于Integer值判斷是否相等的問題

    這篇文章主要介紹了基于Integer值判斷是否相等的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-01-01
  • java中成員變量與局部變量區(qū)別分析

    java中成員變量與局部變量區(qū)別分析

    這篇文章主要介紹了java中成員變量與局部變量區(qū)別,較為詳細的分析了java中成員變量與局部變量的功能、用法與區(qū)別,具有一定參考借鑒價值,需要的朋友可以參考下
    2015-01-01
  • SpringBoot配置及使用Schedule過程解析

    SpringBoot配置及使用Schedule過程解析

    這篇文章主要介紹了SpringBoot配置及使用Schedule過程解析,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-04-04
  • Java編程線程間通信與信號量代碼示例

    Java編程線程間通信與信號量代碼示例

    這篇文章主要介紹了Java編程線程間通信與信號量代碼示例,具有一定借鑒價值,需要的朋友可以參考下。
    2017-12-12
  • Mybatis Log Plugin的使用方式

    Mybatis Log Plugin的使用方式

    這篇文章主要介紹了Mybatis Log Plugin的使用方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-02-02
  • Java 中 Reference用法詳解

    Java 中 Reference用法詳解

    這篇文章主要介紹了Java 中 Reference用法詳解的相關(guān)資料,需要的朋友可以參考下
    2017-03-03
  • java讀取excel圖片導(dǎo)入代碼示例(親測有效)

    java讀取excel圖片導(dǎo)入代碼示例(親測有效)

    在日常工作中,我們經(jīng)常要將一些照片插入到Excel表格中,這篇文章主要給大家介紹了關(guān)于java讀取excel圖片導(dǎo)入的相關(guān)資料,文中通過代碼介紹的非常詳細,需要的朋友可以參考下
    2023-10-10

最新評論