MySQL索引統(tǒng)計(jì)信息更新相關(guān)的參數(shù)有哪些

這篇文章主要講解了“MySQL索引統(tǒng)計(jì)信息更新相關(guān)的參數(shù)有哪些”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來(lái)研究和學(xué)習(xí)“MySQL索引統(tǒng)計(jì)信息更新相關(guān)的參數(shù)有哪些”吧!

網(wǎng)站建設(shè)哪家好,找成都創(chuàng)新互聯(lián)公司!專(zhuān)注于網(wǎng)頁(yè)設(shè)計(jì)、網(wǎng)站建設(shè)、微信開(kāi)發(fā)、小程序開(kāi)發(fā)、集團(tuán)企業(yè)網(wǎng)站建設(shè)等服務(wù)項(xiàng)目。為回饋新老客戶(hù)創(chuàng)新互聯(lián)還提供了三原免費(fèi)建站歡迎大家使用!

MySQL統(tǒng)計(jì)信息相關(guān)的參數(shù):

1. innodb_stats_on_metadata(是否自動(dòng)更新統(tǒng)計(jì)信息),MySQL 5.7中默認(rèn)為關(guān)閉狀態(tài)

僅在統(tǒng)計(jì)信息配置為非持久化的時(shí)候生效。
  也就是說(shuō)在innodb_stats_persistent 配置為OFF的時(shí)候
,非持久化存儲(chǔ)統(tǒng)計(jì)信息的手,innodb_stats_on_metadata的設(shè)置才生效。
  當(dāng)innodb_stats_on_metadata設(shè)置為ON的時(shí)候,
  InnoDB在執(zhí)show table status 或者訪(fǎng)問(wèn)INFORMATION_SCHEMA.TABLES 或者INFORMATION_SCHEMA.STATISTICS 系統(tǒng)表的時(shí)候,更新費(fèi)持久化統(tǒng)計(jì)信息(類(lèi)似于A(yíng)NALYZE TABLE)

某個(gè)索引的統(tǒng)計(jì)信息更新時(shí)間參考mysql.innodb_index_stats這個(gè)系統(tǒng)表
  select * from mysql.innodb_index_stats  where table_name = 'teststatistics';

2. innodb_stats_auto_recalc

是否自動(dòng)觸發(fā)更新統(tǒng)計(jì)信息,僅影響持久化存儲(chǔ)的統(tǒng)計(jì)信息的表,閾值是變化的數(shù)據(jù)超過(guò)表行數(shù)的10%。
  也就是說(shuō),一個(gè)表索引統(tǒng)計(jì)信息是持久化存儲(chǔ)的,并且表中數(shù)據(jù)變化了超過(guò)10%,
  如果innodb_stats_auto_recalc為ON,就會(huì)自動(dòng)更新統(tǒng)計(jì)信息,否則不更新。

3. innodb_stats_persistent(非持久化統(tǒng)計(jì)信息開(kāi)關(guān)),MySQL 5.7中默認(rèn)為打開(kāi),持久化存儲(chǔ)統(tǒng)計(jì)信息

該選項(xiàng)設(shè)置為ON時(shí)候,統(tǒng)計(jì)信息會(huì)持久化存儲(chǔ)到磁盤(pán)中,而不是存在在內(nèi)存中,
  相反,如果是非持久化存儲(chǔ)的(存在內(nèi)存中),相應(yīng)的統(tǒng)計(jì)信息會(huì)隨著服務(wù)器的關(guān)閉而丟失。

4. innodb_stats_persistent_sample_pages (持久化更新統(tǒng)計(jì)信息時(shí)候索引頁(yè)的取樣頁(yè)數(shù)

默認(rèn)是20個(gè)page,如果設(shè)置的過(guò)高,那么在更新統(tǒng)計(jì)信息的時(shí)候,會(huì)增加ANALYZE TABLE的執(zhí)行時(shí)間。

5. innodb_stats_transient_sample_pages(臨時(shí)性更新統(tǒng)計(jì)信息時(shí)候索引頁(yè)的取樣頁(yè)數(shù)

    默認(rèn)值是8,innodb_stats_persistent設(shè)置為disable的情況下innodb_stats_transient_sample_pages才生效
  也就是非持久化存儲(chǔ)過(guò)索引統(tǒng)計(jì)信息的時(shí)候,innodb_stats_transient_sample_pages為更新統(tǒng)計(jì)信息的采樣頁(yè)數(shù)

6. innodb_stats_sample_pages

已棄用. 已用innodb_stats_transient_sample_pages 替代。

======重新收集統(tǒng)計(jì)信息=======

1.分析和存儲(chǔ)表的關(guān)鍵字分布

analyze table table_name;

analyze 用于收集優(yōu)化器的統(tǒng)計(jì)信息、和tuning相關(guān);對(duì) myisam、BOB、innodb起作用。

注意:(經(jīng)過(guò)實(shí)踐操作 在MySQL5.5版本下執(zhí)行sql:analyze table table_name 會(huì)馬上返回一個(gè)ok狀態(tài),但是后端

仍然會(huì)出現(xiàn)鎖表等情況)。

2.檢查表(視圖),檢查一個(gè)或者多個(gè)表是否有錯(cuò)誤

check table table_name;

對(duì)myisam(關(guān)鍵字統(tǒng)計(jì)數(shù)據(jù)被更新)和innodb都有作用,對(duì)于myisam來(lái)說(shuō),需要check和repair(由于myisam表

可能損壞)。

3.定期優(yōu)化表(對(duì)空間碎片進(jìn)行整理合并,消除由于刪除或者更新造成的空間浪費(fèi))

optimize table table_name;

對(duì)myisam,bob和innodb表起作用,但是該操作會(huì)引起鎖表。

optimize 可以回收空間,整理碎片,提高IO 之處 innodb、myisam、archive;如若是replication環(huán)境,可以加no_wri

te_to_binlog。

optimize local table table_name;

感謝各位的閱讀,以上就是“MySQL索引統(tǒng)計(jì)信息更新相關(guān)的參數(shù)有哪些”的內(nèi)容了,經(jīng)過(guò)本文的學(xué)習(xí)后,相信大家對(duì)MySQL索引統(tǒng)計(jì)信息更新相關(guān)的參數(shù)有哪些這一問(wèn)題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是創(chuàng)新互聯(lián),小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

新聞名稱(chēng):MySQL索引統(tǒng)計(jì)信息更新相關(guān)的參數(shù)有哪些
轉(zhuǎn)載注明:http://muchs.cn/article12/jcpddc.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供小程序開(kāi)發(fā)、外貿(mào)網(wǎng)站建設(shè)、用戶(hù)體驗(yàn)軟件開(kāi)發(fā)搜索引擎優(yōu)化、云服務(wù)器

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶(hù)投稿、用戶(hù)轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀(guān)點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話(huà):028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

微信小程序開(kāi)發(fā)