成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Mybatis-Plus很好,但是我被它坑了!

開發 前端
mybatis plus? 給開發人員帶來了很多便利,但是其中也有一些坑點,比如上文所提到得批量操作耗時問題,如果不注意的話,就有可能調入坑里,各位開發同學可以檢查自己或者公司項目中 jdbcurl? 是否缺失 rewriteBatchedStatements=true 參數,加以改正,避免重復掉入這個坑里。

作者今天在開發一個后臺發送消息的功能時,由于需要給多個用戶發送消息,于是使用了 mybatis plus 提供的 saveBatch() 方法,在測試環境測試通過上預發布后,測試反應發送消息接口很慢得等 5、6 秒,于是我就登錄線上環境查看執行日志,發現是 mybatis plus 提供的 saveBatch() 方法執行很慢導致,于是也就有了本篇文章。

mybatis plus 是一個流行的 ORM 框架,它基于 mybatis,提供了很多便利的功能,比如代碼生成器、通用 CRUD、分頁插件、樂觀鎖插件等。它可以讓我們更方便地操作數據庫,減少重復的代碼,提高開發效率。

案發現場還原

/**
 * 先保存通知消息,在批量保存用戶通知記錄
 */
@Transactional(rollbackFor = Exception.class)
@Override
public boolean saveNotice(Notify notify, String receiveUserIds) {
    long begin = System.currentTimeMillis();
    notify.setCreateTime(new Date());
    notify.setCreateBy(ShiroUtil.getSessionUid());
    if (notify.getPublishTime() == null) {
        notify.setPublishTime(new Date());
    }
    boolean insert = save(notify);
    List<NotifyRecord> collect = new ArrayList<>();
    List<String> receiveUserList = fillNotifyRecordList(notify, receiveUserIds, collect);
    notifyRecordService.saveBatch(collect);
    long end = System.currentTimeMillis();
    System.out.println(end - begin);
    ...
    return insert;
}

/**
 * 根據用戶id,組裝用戶通知記錄集合,返回200條記錄
 */
public List<String> fillNotifyRecordList(Notify notify, String receiveUserIds, List<NotifyRecord> collect) {
    List<String> noticeRecordList = new ArrayList<>(200);
    ...
    // 組將兩百條用戶通知記錄
    return noticeRecordList;
}

如上代碼,我有一個 saveNotice() 方法用于保存通知消息以及用戶通知記錄。執行邏輯如下,

  1. 保存通知消息
  2. 根據用戶 id,組裝用戶通知記錄集合,返回 200 條用戶通知記錄
  3. 批量保存用戶通知記錄集合

前兩步驟耗時都很少,我們直接看第三步操作耗時,結合 sql 執行日志,如下,

-- slow sql 5542 millis. INSERT INTO oa_notify_record  ( notifyId, receiveUserId, receiveUserName, isRead,  createTime )  VALUES  ( ?, ?, ?, ?,  ? )[225,"fcd90fe3990e505d07c90a238f75e9c1","niuwawa",false,"2023-10-30 23:54:04"]
5681

再結合 mybatis free log 插件打印完整 sql 如下圖,

圖片圖片

可以看出,我們批量保存用戶通知記錄是一條記錄一條進行保存得,已經可以猜測就是批量插入方法導致得耗時較高。

這里使用得是 mybatis log free 插件,它可以自動幫我們在控制臺打印完整得 mybatis sql 語句。有需要可以在 idea 插件中心搜索 mybatis log free 下載安裝。

結合 saveBatch() 底層源碼也能夠看出,mybatis plus 對于批量操作是通過 for 循環執行保存操作得,源碼如下圖,

圖片圖片

到這里我們也就知道了在測試環境執行較快得原因,因為在測試環境需要批量保存得用戶通知記錄比較少,只有幾條記錄,所以很快。但是上預發布后,由于預發布中需要批量保存得用戶通知記錄比較多達到了數百條,所以執行較慢,耗時達到了 5、6 秒之久。

解決方法

到這里,也就是本文得重點所在了,那怎么解決這個問題嘞?如何既利用 mybatis plus 提供得便攜性,也能夠解決批量操作耗時較高得問題。

其實解決方法很簡單,只需要在 jdbcurl 上添加 rewriteBatchedStatements=true 參數即可解決這個問題。

MySQL 的 JDBC 連接的 url 中要加 rewriteBatchedStatements 參數,并保證 5.1.13 以上版本的驅動,才能實現高性能的批量插入。

MySQL JDBC 驅動在默認情況下會無視 executeBatch()語句,把我們期望批量執行的一組 sql 語句拆散,一條一條地發給 MySQL 數據庫,批量插入實際上是單條插入,直接造成較低的性能。只有把 rewriteBatchedStatements 參數置為 true, 驅動才會幫你批量執行 SQL。另外這個選項對 INSERT/UPDATE/DELETE 都有效。

rewriteBatchedStatements=true 的意思是,當你在 Java 程序中使用批量插入/修改/刪除(batching)時,MySQL JDBC 驅動程序將嘗試重新編寫(rewrite)你的 SQL 語句,以便更有效地執行這些批量插入操作。

OK,在我們給 jdbcurl 上添加了參數后,看看效果,如下圖,

圖片圖片

可以看到 jdbcurl 添加了 rewriteBatchedStatements=true 參數后,批量操作的執行耗時已經只有 200 毫秒,自此也就解決了 mybatis plus 提供的 saveBatch() 方法執行耗時較高得問題。

總結

mybatis plus 給開發人員帶來了很多便利,但是其中也有一些坑點,比如上文所提到得批量操作耗時問題,如果不注意的話,就有可能調入坑里,各位開發同學可以檢查自己或者公司項目中 jdbcurl 是否缺失 rewriteBatchedStatements=true 參數,加以改正,避免重復掉入這個坑里。

責任編輯:武曉燕 來源: waynblog
相關推薦

2023-07-29 22:02:06

MyBatis數據庫配置

2024-12-20 16:49:15

MyBatis開發代碼

2025-02-06 07:45:44

2024-08-27 09:02:21

2023-06-07 08:08:37

MybatisSpringBoot

2025-02-27 09:45:47

2023-06-14 08:34:18

Mybatis死鎖框架

2023-06-07 08:00:00

MySQL批量插入

2013-06-20 11:11:00

程序員經理

2022-07-15 13:58:46

工具MyBatissql

2025-06-13 09:30:50

2020-04-14 10:06:20

微服務Netflix語言

2025-05-26 03:20:00

SpringMyBatis數據權限

2024-02-28 09:35:52

2024-11-28 19:03:56

2024-07-31 09:56:20

2023-01-12 09:13:49

Mybatis數據庫

2025-02-13 07:59:13

2023-01-17 09:13:08

Mybatis后端框架

2024-01-15 09:15:52

parallel語句函數
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 亚洲一区二区在线视频 | 色网站视频 | 亚洲精品久久久久久宅男 | 二区亚洲| 黄色一级电影免费观看 | 99久久婷婷国产综合精品电影 | 亚洲欧美一区二区三区国产精品 | 国产免费一区二区 | 免费精品一区 | 97热在线 | 亚洲情侣视频 | 亚洲社区在线 | 亚洲综合色丁香婷婷六月图片 | 亚洲成人999| 欧美在线一区二区三区 | 国产日韩视频在线 | 欧美激情欧美激情在线五月 | 激情a | 国产区视频在线观看 | 免费视频一区二区 | a级免费观看视频 | 国产第一区二区 | 色婷婷国产精品 | 亚洲日韩中文字幕一区 | 成年人免费看的视频 | 久久精品一区二区三区四区 | 91在线视频免费观看 | 欧美日韩在线一区二区 | 久久久久久久一区二区三区 | 美女视频黄的免费 | 成人性视频免费网站 | 成人精品国产一区二区4080 | 中文字幕亚洲一区 | 精品欧美乱码久久久久久1区2区 | 欧美日韩视频在线播放 | 欧美爱爱视频 | 一区二区不卡视频 | 国产成人精品一区二区三区四区 | 日韩精品久久 | 国产精品久久久久久久免费观看 | 国产精品国色综合久久 |