真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

MySQL統(tǒng)計(jì)信息的示例分析

這篇文章主要為大家展示了“MySQL統(tǒng)計(jì)信息的示例分析”,內(nèi)容簡(jiǎn)而易懂,條理清晰,希望能夠幫助大家解決疑惑,下面讓小編帶領(lǐng)大家一起研究并學(xué)習(xí)一下“MySQL統(tǒng)計(jì)信息的示例分析”這篇文章吧。

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括鶴壁網(wǎng)站建設(shè)、鶴壁網(wǎng)站制作、鶴壁網(wǎng)頁制作以及鶴壁網(wǎng)絡(luò)營(yíng)銷策劃等。多年來,我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,鶴壁網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到鶴壁省份的部分城市,未來相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

MySQL統(tǒng)計(jì)信息的存儲(chǔ)分為兩種,非持久化和持久化統(tǒng)計(jì)信息。

一、非持久化統(tǒng)計(jì)信息

非持久化統(tǒng)計(jì)信息存儲(chǔ)在內(nèi)存里,如果數(shù)據(jù)庫重啟,統(tǒng)計(jì)信息將丟失。有兩種方式可以設(shè)置為非持久化統(tǒng)計(jì)信息:

1 全局變量,

INNODB_STATS_PERSISTENT=OFF

2 CREATE/ALTER表的參數(shù),

STATS_PERSISTENT=0

非持久化統(tǒng)計(jì)信息在以下情況會(huì)被自動(dòng)更新:

1 執(zhí)行ANALYZE TABLE

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

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

4 表第一次被打開

5 距上一次更新統(tǒng)計(jì)信息,表1/16的數(shù)據(jù)被修改

非持久化統(tǒng)計(jì)信息的缺點(diǎn)顯而易見,數(shù)據(jù)庫重啟后如果大量表開始更新統(tǒng)計(jì)信息,會(huì)對(duì)實(shí)例造成很大影響,所以目前都會(huì)使用持久化統(tǒng)計(jì)信息。

二、持久化統(tǒng)計(jì)信息

5.6.6開始,MySQL默認(rèn)使用了持久化統(tǒng)計(jì)信息,即INNODB_STATS_PERSISTENT=ON,持久化統(tǒng)計(jì)信息保存在表mysql.innodb_table_stats和mysql.innodb_index_stats。

持久化統(tǒng)計(jì)信息在以下情況會(huì)被自動(dòng)更新:

1 INNODB_STATS_AUTO_RECALC=ON

情況下,表中10%的數(shù)據(jù)被修改

2 增加新的索引 

innodb_table_stats是表的統(tǒng)計(jì)信息,innodb_index_stats是索引的統(tǒng)計(jì)信息,各字段含義如下:

innodb_table_stats

database_name

數(shù)據(jù)庫名

table_name

表名

last_update

統(tǒng)計(jì)信息最后一次更新時(shí)間

n_rows

表的行數(shù)

clustered_index_size

聚集索引的頁的數(shù)量

sum_of_other_index_sizes

其他索引的頁的數(shù)量

innodb_index_stats

database_name

數(shù)據(jù)庫名

table_name

表名

index_name

索引名

last_update

統(tǒng)計(jì)信息最后一次更新時(shí)間

stat_name

統(tǒng)計(jì)信息名

stat_value

統(tǒng)計(jì)信息的值

sample_size

采樣大小

stat_description

類型說明

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

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;

寫入數(shù)據(jù)如下:

MySQL統(tǒng)計(jì)信息的示例分析

查看t1表的統(tǒng)計(jì)信息,需主要關(guān)注stat_name和stat_value字段

MySQL統(tǒng)計(jì)信息的示例分析

tat_name=size時(shí):stat_value表示索引的頁的數(shù)量

stat_name=n_leaf_pages時(shí):stat_value表示葉子節(jié)點(diǎn)的數(shù)量

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

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

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

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

了解了stat_name和stat_value的具體含義,就可以協(xié)助我們排查SQL執(zhí)行時(shí)為什么沒有使用合適的索引,例如某個(gè)索引n_diff_pfxNN的stat_value遠(yuǎn)小于實(shí)際值,查詢優(yōu)化器認(rèn)為該索引選擇度較差,就有可能導(dǎo)致使用錯(cuò)誤的索引。

三、統(tǒng)計(jì)信息不準(zhǔn)確的處理

我們查看執(zhí)行計(jì)劃,發(fā)現(xiàn)未使用正確的索引,如果是innodb_index_stats中統(tǒng)計(jì)信息差別較大引起,可通過以下方式處理:

1、手動(dòng)更新統(tǒng)計(jì)信息,注意執(zhí)行過程中會(huì)加讀鎖:

ANALYZETABLE TABLE_NAME;

2、如果更新后統(tǒng)計(jì)信息仍不準(zhǔn)確,可考慮增加表采樣的數(shù)據(jù)頁,兩種方式可以修改:

a) 全局變量INNODB_STATS_PERSISTENT_SAMPLE_PAGES,默認(rèn)為20;

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

ALTER TABLE TABLE_NAME STATS_SAMPLE_PAGES=40;

經(jīng)測(cè)試,此處STATS_SAMPLE_PAGES的最大值是65535,超出會(huì)報(bào)錯(cuò)。

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

以上是“MySQL統(tǒng)計(jì)信息的示例分析”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注創(chuàng)新互聯(lián)行業(yè)資訊頻道!


分享名稱:MySQL統(tǒng)計(jì)信息的示例分析
文章URL:http://weahome.cn/article/ijcoih.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部