溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊(cè)×
其他方式登錄
點(diǎn)擊 登錄注冊(cè) 即表示同意《億速云用戶服務(wù)條款》

MySQL5.6怎么快速定位不合理索引

發(fā)布時(shí)間:2021-09-16 15:35:37 來源:億速云 閱讀:151 作者:chen 欄目:MySQL數(shù)據(jù)庫

這篇文章主要講解了“MySQL5.6怎么快速定位不合理索引”,文中的講解內(nèi)容簡(jiǎn)單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“MySQL5.6怎么快速定位不合理索引”吧!


# 若CARDINALITY / TABLE_ROWS小于10%(經(jīng)驗(yàn)值),那么表示數(shù)據(jù)重復(fù)率較高,通常需要考慮是否有必要?jiǎng)?chuàng)建該索引


#########################################################
# mysql 5.6
目前5.6的STATISTICS表中關(guān)于Cardinality的統(tǒng)計(jì)是錯(cuò)誤的?。。【唧w可見MySQL bugs #78066。
但是,表innodb_index_stats中關(guān)于Cardinality值得統(tǒng)計(jì)依然是正確的  
#########################################################
SELECT 
     t.TABLE_SCHEMA,
     t.TABLE_NAME,INDEX_NAME,
     s.CARDINALITY, 
     t.TABLE_ROWS, 
     s.CARDINALITY/t.TABLE_ROWS AS SELECTIVITY
FROM
    information_schema.TABLES t,
    (SELECT database_name,table_name,index_name,stat_value AS CARDINALITY
     FROM mysql.innodb_index_stats 
     WHERE (database_name,table_name,index_name,stat_name) IN 
           (SELECT table_schema,table_name,index_name,CONCAT('n_diff_pfx0',MAX(seq_in_index))
              FROM information_schema.STATISTICS
          -- where table_name='xxxxx' 
          GROUP BY table_schema , table_name , index_name )) s
WHERE t.table_schema = s.database_name 
  AND t.table_name = s.table_name 
  AND t.table_rows != 0
  AND t.table_schema NOT IN ( 'mysql','performance_schema','information_schema') 
ORDER BY SELECTIVITY;

以下部分出自:http://mp.weixin.qq.com/s?__biz=MjM5MjIxNDA4NA==&mid=401131835&idx=1&sn=37c5fd9d3d8670fb379a1e0565e50eeb&scene=0#wechat_redirect
#############################################################
# mysql 5.7  表STATISTICS記錄了各個(gè)索引的CARDINALITY值
#############################################################

SELECT 
     t.TABLE_SCHEMA,t.TABLE_NAME,INDEX_NAME, CARDINALITY, 
    TABLE_ROWS, CARDINALITY/TABLE_ROWS AS SELECTIVITY
FROM
    information_schema.TABLES t,
 (
  SELECT table_schema,table_name,index_name,cardinality
  FROM information_schema.STATISTICS 
  WHERE (table_schema,table_name,index_name,seq_in_index) IN (
  SELECT table_schema,table_name,index_name,MAX(seq_in_index)
  FROM information_schema.STATISTICS
  GROUP BY table_schema , table_name , index_name )
 ) s
WHERE
    t.table_schema = s.table_schema 
        AND t.table_name = s.table_name AND t.table_rows != 0
        AND t.table_schema NOT IN ( 'mysql','performance_schema','information_schema') 
ORDER BY SELECTIVITY;

感謝各位的閱讀,以上就是“MySQL5.6怎么快速定位不合理索引”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)MySQL5.6怎么快速定位不合理索引這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI