亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 數據庫 > MySQL > 正文

概述MySQL統計信息

2024-07-24 13:15:28
字體:
來源:轉載
供稿:網友

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越來越強大的功能吧!


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美另类人妖| 538国产精品一区二区在线| 欧美性资源免费| 69av视频在线播放| 91精品美女在线| 日本精品视频在线| 在线日韩第一页| 欧美亚洲国产视频小说| 97超级碰在线看视频免费在线看| 视频在线观看99| 97人洗澡人人免费公开视频碰碰碰| 亚洲理论片在线观看| 日韩国产高清视频在线| 亚洲免费精彩视频| 黄网动漫久久久| 中文字幕亚洲欧美日韩在线不卡| 久久久久久有精品国产| 亚洲片在线资源| 国产精品久久久久久久久免费| 亚洲国产精品成人va在线观看| 亚洲精品狠狠操| 超碰日本道色综合久久综合| 国产欧美亚洲精品| 亚洲日本欧美中文幕| 国产精品视频网站| 欧美极品少妇xxxxⅹ裸体艺术| 96sao精品视频在线观看| 国产经典一区二区| 国产伦精品一区二区三区精品视频| 自拍偷拍亚洲欧美| 国产在线精品成人一区二区三区| 亚洲精品国产suv| 自拍亚洲一区欧美另类| 国产99久久精品一区二区 夜夜躁日日躁| 久久大大胆人体| 精品国产乱码久久久久久婷婷| 庆余年2免费日韩剧观看大牛| 久久久久久网站| 91在线观看免费观看| 精品动漫一区二区三区| 伊人亚洲福利一区二区三区| 久久精品99国产精品酒店日本| 国产精品久久久久久久久粉嫩av| 久久久精品999| 亚洲精品福利在线观看| 不卡av在线播放| 亚洲电影在线看| 国产精品视频一| 精品久久久久久久久久久久久| 久久最新资源网| 色综合久久久久久中文网| 69**夜色精品国产69乱| 欧美专区在线观看| 久久久国产精彩视频美女艺术照福利| 亚洲伊人久久综合| 国产成人综合av| 伊人男人综合视频网| 亚洲成av人片在线观看香蕉| 日本欧美精品在线| 日韩一中文字幕| 久久久久久网址| 亚洲iv一区二区三区| 久久精品国产一区二区电影| 欧美高清在线播放| 国产精品一区二区性色av| 国产日韩视频在线观看| 97久久精品视频| 国产亚洲日本欧美韩国| 亚洲欧美国产精品va在线观看| 国产亚洲人成a一在线v站| 欧美日韩亚洲成人| 久久成人这里只有精品| 欧美一区第一页| 日韩美女毛茸茸| 欧美日韩国产丝袜另类| 91精品国产精品| 国产精品中文在线| 欧美日韩在线影院| 精品成人av一区| 久久国产加勒比精品无码| 亚洲日本中文字幕| 久久久国产影院| 日韩在线视频二区| 日韩精品在线免费播放| 欧美午夜视频一区二区| 国产脚交av在线一区二区| 国产精品免费小视频| 91在线免费视频| 欧美精品videofree1080p| 欧美高跟鞋交xxxxxhd| 成人疯狂猛交xxx| 亚洲精品视频久久| 大伊人狠狠躁夜夜躁av一区| 91产国在线观看动作片喷水| 亚洲国产精品中文| 国产免费一区视频观看免费| 8x海外华人永久免费日韩内陆视频| 欧美午夜精品在线| 欧美伦理91i| 亚洲国产精品人人爽夜夜爽| 欧美激情极品视频| 亚洲日本中文字幕免费在线不卡| 亚洲福利精品在线| 国产欧美欧洲在线观看| 亚洲高清福利视频| 在线观看中文字幕亚洲| 亚洲欧美一区二区三区四区| 亚洲最大的免费| 久久精品国产亚洲| 91精品美女在线| 亚洲最新av网址| 国产女精品视频网站免费| 久久久久中文字幕2018| 日本一区二区在线播放| 久久综合亚洲社区| 亚洲人成啪啪网站| 亚洲欧美日韩在线一区| 欧美成人性色生活仑片| 97视频免费看| 成人欧美一区二区三区黑人孕妇| 国语自产精品视频在线看一大j8| 亚洲毛片在线看| 欧美精品激情在线观看| 91亚洲精品在线| 亚洲一区二区三区xxx视频| 精品视频偷偷看在线观看| 亚洲国产一区二区三区在线观看| 色悠悠国产精品| 欧美极度另类性三渗透| 欧美午夜无遮挡| 国产福利视频一区二区| 91综合免费在线| 亚洲欧洲激情在线| 国产精品亚洲综合天堂夜夜| 亚洲人成网站色ww在线| 欧美另类69精品久久久久9999| 成人疯狂猛交xxx| 亚洲久久久久久久久久| 欧美国产亚洲精品久久久8v| 国产亚洲人成网站在线观看| 国产亚洲精品va在线观看| 国产99在线|中文| 欧美精品免费在线观看| 国产精品一区二区久久国产| 欧美激情视频播放| 欧美日韩免费一区| 国产亚洲成av人片在线观看桃| 成人www视频在线观看| 国产一区二区黑人欧美xxxx| 中文字幕精品av| 久久精品国产精品| 91国偷自产一区二区三区的观看方式| 97香蕉超级碰碰久久免费软件| 欧美电影院免费观看| 97在线视频免费观看| 91av成人在线| 日韩精品视频免费专区在线播放| 国产日韩在线视频| 亚洲天堂色网站| 欧美在线视频观看免费网站| 欧美人成在线视频| 国产婷婷成人久久av免费高清| 91美女片黄在线观| 欧美一区二区三区免费观看|