詳解MyBatis-Puls中saveBatch批量添加慢的問題
問題
在項目過程中使用MyBatis-Puls的saveBatch一次性添加大量數(shù)據(jù)時很慢
原因
MyBatis-Puls的saveBatch默認并沒有批量添加,實際上在插入的時候仍然是一條條記錄的插,速度遠不如原來Mybatis的foreach拼接SQL的方法
測試
模擬使用saveBatch添加一萬條數(shù)據(jù)
結(jié)果
結(jié)果可以看到輸出的總耗時為5685,而上面的SQL日志可以證明數(shù)據(jù)是一條一條插入的
優(yōu)化
只需要在JDBC連接URL字符串中需要新增一個參數(shù):rewriteBatchedStatements=true
這樣可以讓saveBatch實現(xiàn)批處理方式
重新執(zhí)行后效果:最終耗時2948,幾乎快了一半
關于rewriteBatchedStatements這個參數(shù)介紹:
MySQL的JDBC連接的url中要加rewriteBatchedStatements參數(shù),并保證5.1.13以上版本的驅(qū)動,才能實現(xiàn)高性能的批量插入。
MySQL JDBC驅(qū)動在默認情況下會無視executeBatch()語句,把我們期望批量執(zhí)行的一組sql語句拆散,一條一條地發(fā)給MySQL數(shù)據(jù)庫,批量插入實際上是單條插入,直接造成較低的性能。
只有把rewriteBatchedStatements參數(shù)置為true, 驅(qū)動才會幫你批量執(zhí)行SQL
另外這個選項對INSERT/UPDATE/DELETE都有效
到此這篇關于詳解MyBatis-Puls中saveBatch批量添加慢的問題的文章就介紹到這了,更多相關MyBatis-Puls saveBatch批量添加慢內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
SpringMVC+EasyUI實現(xiàn)頁面左側(cè)導航菜單功能
這篇文章主要介紹了SpringMVC+EasyUI實現(xiàn)頁面左側(cè)導航菜單功能,本文通過實例代碼給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09eclipse+maven+spring mvc項目基本搭建過程
這篇文章主要介紹了eclipse+maven+spring mvc項目基本搭建過程,本文圖文并茂給大家介紹的非常詳細,具有一定的參考借鑒價值,需要的朋友可以參考下2019-09-09