網站首頁 編程語言 正文
? ? 最近線上發版的時候,發現有個接口執行特別慢,前端App的表現就是沒有任何的反應,然后從pinpoint上追查接口發現是sql執行特別慢,平均都是在9s左右。這里由于使用了分頁查詢的 Mybatis interceptor所以同樣的sql還需要查詢一次count,導致整個耗時在9s左右,單個sql的耗時在5-6秒左右。
? ? 線上有一張訂單表數據大概是65萬條數據,另一張訂單配送任務表數據大概也是65萬條數據,有一條sql的 inner join兩張表,執行的sql大致如下:
?基于我對join優化的本能(join優化分析博客:Mysql - join(索引和非索引)的實現原理和優化手段也可以參考:https://www.processon.com/view/link/5ff1684ee0b34d19e4f89031),首先想到的就是是否使用了 Index Nested Loop Join,但是一看兩個join on的字段都是有索引的。就先看了一下執行計劃,如下:
? ? 該執行計劃顯示一張 65萬的數據走了全表掃描,使用了臨時表、使用了排序(注意這里寫的 filesort可能是內存排序不一定是文件排序)。出于本能我想到了將小表作為驅動表,但是本能也是將兩張表的位置進行了交互,但是發現效果沒有太大區別。
? ? 我們趕快翻我寫的processon上的優化注意點,試著將 inner join換成了 straght_join,就這一個小小的改動整個耗時從 6s變成了 400ms,我一下子就懵了,馬上看了一下執行計劃,如下:
?兩個表的 ALL、ref變成了 eq_ref、ref,并且兩個的key都使用了索引,Extra這里沒有了臨時表,增加了 Usingwherecondition。事后翻盤如果是兩個表的數據相差很大這個效果是接受的,但是兩個表的數據量都相當,這個性能提升和執行計劃還是有點懵的,希望高手幫解惑。
?在列一下從pinpoint上看到的使用 inner join和 straight_join的性能對比:
原文鏈接:https://blog.csdn.net/it_lihongmin/article/details/122334143
- 上一篇:C 語言中一些重要關鍵字
- 下一篇:Springboot + Redis 哨兵模式
相關推薦
- 2022-02-25 .gitignore 中增加了 .idea/ workspace.xml失效解決方案
- 2022-06-28 react18中react-redux狀態管理的實現_React
- 2022-10-07 C語言直接選擇排序算法詳解_C 語言
- 2022-03-29 Android中的xml解析介紹_Android
- 2022-05-19 Python學習之異常處理的避坑指南_python
- 2022-02-25 C++實現單例模式的方法_C 語言
- 2022-05-07 LINQ教程之LINQ操作語法_實用技巧
- 2024-03-04 新版ECharts實現“暫無數據”的完美解決方案
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支