MySQL統計資訊的儲存分為兩種,非持久化和持久化統計資訊。
非持久化統計資訊儲存在記憶體裡,如果資料庫重啟,統計資訊將丟失。有兩種方式可以設定為非持久化統計資訊:
非持久化統計資訊的缺點顯而易見,資料庫重啟後如果大量表開始更新統計資訊,會對例項造成很大影響,所以目前都會使用持久化統計資訊。
二、持久化統計資訊
,持久化統計資訊儲存在表和。是表的統計資訊,是索引的統計資訊,各欄位含義如下:為更好的理解,建一張測試表做說明:CREATE TABLE t1 (
a INT, b INT, c INT, d INT, e INT, f INT,
PRIMARY KEY (a, b), KEY i1 (c, d), UNIQUE KEY i2uniq (e, f)
) ENGINE=INNODB;複製程式碼
和欄位時:表示索引的頁的數量時:表示葉子節點的數量時:表示索引欄位上唯一值的數量,此處做一下具體說明:表示索引第一列之後的數量,如的a列,只有一個值1,所以時,。表示索引前兩列之後的數量,如的列,有4個值,所以時,。,在原索引列c,d後加了主鍵列的結果為2。和的具體含義,就可以協助我們排查SQL執行時為什麼沒有使用合適的索引,例如某個索引的遠小於實際值,查詢優化器認為該索引選擇度較差,就有可能導致使用錯誤的索引。中統計資訊差別較大引起,可通過以下方式處理:;2、如果更新後統計資訊仍不準確,可考慮增加表取樣的資料頁,兩種方式可以修改:
,預設為20;;的最大值是65535,超出會報錯。目前MySQL並沒有提供直方圖的功能,某些情況下(如資料分佈不均)僅僅更新統計資訊不一定能得到準確的執行計劃,只能通過
的方式指定索引。新版本8.0會增加直方圖功能,讓我們期待MySQL越來越強大的功能吧!