六月婷婷综合激情-六月婷婷综合-六月婷婷在线观看-六月婷婷在线-亚洲黄色在线网站-亚洲黄色在线观看网站

明輝手游網中心:是一個免費提供流行視頻軟件教程、在線學習分享的學習平臺!

MySQL統計信息的詳細概述

[摘要]本篇文章通過統計信息的概念介紹以及MYSQL統計信息的優勢等方面全面概述了MySQL統計信息的相關知識點,希望可以幫助到有需求的朋友們。MySQL執行SQL會經過SQL解析和查詢優化的過程,解析器將...
本篇文章通過統計信息的概念介紹以及MYSQL統計信息的優勢等方面全面概述了MySQL統計信息的相關知識點,希望可以幫助到有需求的朋友們。

MySQL執行SQL會經過SQL解析和查詢優化的過程,解析器將SQL分解成數據結構并傳遞到后續步驟,查詢優化器發現執行SQL查詢的最佳方案、生成執行計劃。查詢優化器決定SQL如何執行,依賴于數據庫的統計信息,下面我們介紹MySQL 5.7中innodb統計信息的相關內容。

MySQL統計信息的存儲分為兩種,非持久化和持久化統計信息。

一、非持久化統計信息

非持久化統計信息存儲在內存里,如果數據庫重啟,統計信息將丟失。有兩種方式可以設置為非持久化統計信息:

1 全局變量,

INNODB_STATS_PERSISTENT=OFF

2 CREATE/ALTER表的參數,

STATS_PERSISTENT=0

非持久化統計信息在以下情況會被自動更新:

1 執行ANALYZE TABLE

2 innodb_stats_on_metadata=ON情況下,執SHOW TABLE STATUS, SHOW INDEX, 查詢 INFORMATION_SCHEMA下的TABLES, STATISTICS

3 啟用--auto-rehash功能情況下,使用mysql client登錄

4 表第一次被打開

5 距上一次更新統計信息,表1/16的數據被修改

非持久化統計信息的缺點顯而易見,數據庫重啟后如果大量表開始更新統計信息,會對實例造成很大影響,所以目前都會使用持久化統計信息。

二、持久化統計信息

5.6.6開始,MySQL默認使用了持久化統計信息,即INNODB_STATS_PERSISTENT=ON,持久化統計信息保存在表mysql.innodb_table_stats和mysql.innodb_index_stats。

持久化統計信息在以下情況會被自動更新:


1 INNODB_STATS_AUTO_RECALC=ON

情況下,表中10%的數據被修改

2 增加新的索引

innodb_table_stats是表的統計信息,innodb_index_stats是索引的統計信息,各字段含義如下:

innodb_table_stats

database_name

數據庫名

table_name

表名

last_update

統計信息最后一次更新時間

n_rows

表的行數

clustered_index_size

聚集索引的頁的數量

sum_of_other_index_sizes

其他索引的頁的數量


innodb_index_stats

database_name

數據庫名

table_name

表名

index_name

索引名

last_update

統計信息最后一次更新時間

stat_name

統計信息名

stat_value

統計信息的值

sample_size

采樣大小

stat_description

類型說明

為更好的理解innodb_index_stats,建一張測試表做說明:

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;

寫入數據如下:

MySQL統計信息的詳細概述

查看t1表的統計信息,需主要關注stat_name和stat_value字段

MySQL統計信息的詳細概述

tat_name=size時:stat_value表示索引的頁的數量

stat_name=n_leaf_pages時:stat_value表示葉子節點的數量

stat_name=n_diff_pfxNN時:stat_value表示索引字段上唯一值的數量,此處做一下具體說明:

1、n_diff_pfx01表示索引第一列distinct之后的數量,如PRIMARY的a列,只有一個值1,所以index_name='PRIMARY' and stat_name='n_diff_pfx01'時,stat_value=1。

2、n_diff_pfx02表示索引前兩列distinct之后的數量,如i2uniq的e,f列,有4個值,所以index_name='i2uniq' and stat_name='n_diff_pfx02'時,stat_value=4。

3、對于非唯一索引,會在原有列之后加上主鍵索引,如index_name='i1' and stat_name='n_diff_pfx03',在原索引列c,d后加了主鍵列a,(c,d,a)的distinct結果為2。

了解了stat_name和stat_value的具體含義,就可以協助我們排查SQL執行時為什么沒有使用合適的索引,例如某個索引n_diff_pfxNN的stat_value遠小于實際值,查詢優化器認為該索引選擇度較差,就有可能導致使用錯誤的索引。

三、統計信息不準確的處理

我們查看執行計劃,發現未使用正確的索引,如果是innodb_index_stats中統計信息差別較大引起,可通過以下方式處理:

1、手動更新統計信息,注意執行過程中會加讀鎖:

ANALYZETABLE TABLE_NAME;

2、如果更新后統計信息仍不準確,可考慮增加表采樣的數據頁,兩種方式可以修改:

a) 全局變量INNODB_STATS_PERSISTENT_SAMPLE_PAGES,默認為20;

b) 單個表可以指定該表的采樣:

ALTER TABLE TABLE_NAME STATS_SAMPLE_PAGES=40;

經測試,此處STATS_SAMPLE_PAGES的最大值是65535,超出會報錯。

目前MySQL并沒有提供直方圖的功能,某些情況下(如數據分布不均)僅僅更新統計信息不一定能得到準確的執行計劃,只能通過index hint的方式指定索引。新版本8.0會增加直方圖功能,讓我們期待MySQL越來越強大的功能吧!

相關推薦:

實例解析:統計信息管理、Spring注解開發和EasyUI

收集SQL Server統計信息_PHP教程

以上就是MySQL統計信息的詳細概述的詳細內容,更多請關注php中文網其它相關文章!


學習教程快速掌握從入門到精通的SQL知識。




主站蜘蛛池模板: 欧美在线免费观看视频 | 日本人的一区二区三区四区 | 欧美天堂在线 | 色橹橹欧美在线观看视频高清 | 日本高清在线观看视频 | 日韩天堂在线观看 | 啪啪午夜| 一级黄色片免费的 | 亚洲欧美一区二区三区久久 | 亚洲精品免费在线视频 | 色婷婷99综合久久久精品 | 青娱乐极品视频在线 | 亚洲成人看片 | 欧美在线观看高清一二三区 | 日本爽爽爽爽爽爽在线观看免 | 亚洲h视频在线观看 | 中文国产成人久久精品小说 | 日韩精品一区二区三区中文 | 天天草天天干天天 | 色六月婷婷| 日韩视频精品在线 | 亚洲视频在线免费观看 | 亚洲综合偷自成人网第页色 | 亚洲高清免费在线观看 | 日本中文字幕视频 | 亚洲综合色区中文字幕 | 欧洲呦女网站 | 欧美婷婷六月丁香综合色 | 色噜噜狠狠色综合网图区 | 一级特级女人18毛片免费视频 | 亚洲产国偷v产偷v自拍涩爱 | 五月综合激情网 | 日本www色高清视频 日本www免费 | 欧美在线区 | 亚洲va国产va天堂va久久 | 亚洲五月综合网色九月色 | 小情侣旅馆内无套啪啪 | 青娱乐在线视频播放 | 综合久久久久久 | 亚洲一区二区三区在线免费观看 | 青青草 久久久 |