MySQL InnoDB什麼時候更新索引的統計信息?

来源:https://www.cnblogs.com/kerrycode/archive/2023/09/28/17735459.html
-Advertisement-
Play Games

MySQL InnoDB的索引統計信息在什麼時候更新呢? 或者說什麼事件會觸發InnoDB索引的統計信息更新呢?下麵結合參考資料When Does InnoDB Update the Index Statistics? (Doc ID 1463718.1)[1]簡單總結梳理一下(文中大部分知識點來自 ...


MySQL InnoDB的索引統計信息在什麼時候更新呢? 或者說什麼事件會觸發InnoDB索引的統計信息更新呢?下麵結合參考資料When Does InnoDB Update the Index Statistics? (Doc ID 1463718.1)[1]簡單總結梳理一下(文中大部分知識點來自參考資料)。

1: ANALYZE TABLE命令

ANALYZE TABLE命令會顯式強制更新表的索引統計信息。例子:

ANALYZE TABLE <TABLE_NAME>;

2:OPTIMIZE TABLE命令

對InnoDB的表執行OPTIMIZE TABLE命令時, OPTIMIZE TABLE重新組織表的數據和關聯索引數據的物理存儲,以減少存儲空間並提高訪問表時的I/O效率。通俗點理解就是碎片整理。它會重建表並執行ANALYZE TABLE命令,因此索引的統計信息也會被更新。

3:元數據查看觸發

如果您開啟了瞬態統計信息(transient statistics)並且innodb_stats_on_metadata參數為ON(MySQL 5.5及更早版本中的預設值,但在MySQL 5.6及更高版本中不是預設值)的話,那麼InnoDB會在以下情況下更新索引的統計信息:

查詢元數據信息的SQL語句:

  • SHOW TABLE STATUS
  • SHOW INDEX

或者當你訪問INFORMATION_SCHEMA下一些表時也會觸發統計信息更新,例如:

  • TABLES
  • STATISTICS。

其實實際環境中,這種條件很少觸發索引更新統計信息,因為它的條件一般很難滿足,正常情況下,這些參數都不會這樣設置。

另外這裡補充一下transient statistics的知識:

關於瞬態統計信息(transient statistics), 其實transient statistics也叫non-persistent optimizer statistics,翻譯成非持久統計信息,它是當innodb_stats_persistent=OFF 或使用 STATS_PERSISTENT=0時,創建或更改單個表時,優化程式統計信息不會保存到磁碟。相反,統計信息存儲在記憶體中,併在伺服器關閉時丟失。統計信息也會通過某些操作和特定條件下定期更新。

4 統計信息自動更新

對於使用瞬態統計信息的表,統計信息是在首次打開表時計算的。這包括FLUSH TABLE和FLUSH TABLES WITH READ LOCK。

此外,當表的有大量數據發生變化時,InnoDB還將觸發重新計算索引統計信息。邏輯取決於使用的是持久統計信息還是瞬態統計信息:

  • 持久統計信息:為表啟用 STATS_AUTO_RECALC(預設情況下設置為預設啟用的 innodb_stats_auto_recalc 值)時,當 1/10 (10%) 行發生更改時,索引統計信息將更新,限製為每次更新之間必須至少經過 10 秒。

  • 瞬態統計信息:自上次更新統計信息以來,表中至少 1/16 (6.25%) 的行已被修改。

另外,關於transient statistics,其實有些版本還是有一些Bug的,例如Bug #98546 Transient indexes statistics are updated in foreground causing performance issue

參考資料

[1]

1: https://support.oracle.com/epmos/faces/DocumentDisplay?_afrLoop=342584987828510&id=1463718.1&_afrWindowMode=0&_adf.ctrl-state=5hdz2z4vn_4,

掃描上面二維碼關註我 如果你真心覺得文章寫得不錯,而且對你有所幫助,那就不妨幫忙“推薦"一下,您的“推薦”和”打賞“將是我最大的寫作動力! 本文版權歸作者所有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接.
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • https://www.codenong.com/cs106719464/ WinForm中的UI假死其實是個老生常談的問題了,但最近還是很多人問我該如何解決,所以今天就來說明一下如何解決UI假死的問題。實驗程式界面如下圖所示: 方法一:async + await + Task 首先看下麵一段代碼: ...
  • C# BeginInvoke實現非同步編程-CSDN博客 https://blog.csdn.net/Nire_Yeyu/article/details/133203267 C# BeginInvoke實現非同步編程BeginInvoke實現非同步編程的三種模式: 1.等待模式在發起了非同步方法以及做了一些 ...
  • 模擬.NET實際應用場景,綜合應用三個主要知識點:一是使用dnSpy反編譯第三庫及調試,二是使用Lib.Harmony庫實現第三庫攔截、偽造,三是實現同一個庫支持多版本同時引用。 ...
  • 問題現象: 使用伺服器管理器打開本地安全策略,或使用win+R快捷鍵,輸入gpedit.msc打開系統組策略時,出現報錯:無法打開此電腦上的組策略對象。你可能沒有相應的許可權。 解決方法: 1、使用win+E快捷鍵打開資源管理器,點擊”查看“,勾選”隱藏的項目“,因為C:\Windows\Syste ...
  • 一、介紹說明 Linux系統是一個多用戶多任務的操作系統,任何一個要使用系統資源的用戶,都必須首先向系統管理員申請一個賬號,然後以這個賬號的身份進入系統。 用戶的賬號一方面可以幫助系統管理員對使用系統的用戶進行跟蹤,並控制他們對系統資源的訪問;另一方面也可以幫助用戶組織文件,併為用戶提供安全性保護。 ...
  • PostgreSQL 在開源資料庫世界中一直是一個標誌性的存在。經過35年的嚴格開發,它以其可靠性、強大的功能和性能而自豪。DB-engines 的突出顯示,其市場份額的增長證明瞭其適應性強的數據模型和滿足各種用例需求的多樣化擴展 考慮到PG突出的地位,甲骨文將推出基於 PostgreSQL 14. ...
  • 在資料庫代理層中,寫節點的資料庫連接是一種很重要和稀缺的資源,提升其利用率是一個提升資料庫整體性能的重要手段。資料庫連接占用過高會大幅增加資料庫的資源負擔,降低資料庫的處理能力。通過延遲啟動的事務,可以減少不必要的連接占用時長,提升資料庫連接利用率。 ...
  • SQL改寫是資料庫產品中使用比較頻繁的一個技術,在大多數產品中的調用頻率也非常高,通常對性能的需求需要接近對應資料庫產品的上限。例如在天翼雲關係型資料庫中的Mysql語法相容組件,其性能測試標準需要達到接近30萬TPS,也意味著SQL改寫環節的性能標準需要支持至少每秒30萬次以上,否則會成為系統的性... ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...