欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

MySQL查詢冗余索引和未使用過的索引操作

 更新時間:2021年03月30日 09:22:59   作者:遺失的曾經!  
這篇文章主要介紹了MySQL查詢冗余索引和未使用過的索引操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧

MySQL5.7及以上版本提供直接查詢冗余索引、重復索引和未使用過索引的視圖,直接查詢即可。

查詢冗余索引、重復索引

select * sys.from schema_redundant_indexes;

查詢未使用過的索引

select * from sys.schema_unused_indexes;

如果想在5.6和5.5版本使用,將視圖轉換成SQL語句查詢即可

查詢冗余索引、重復索引

select a.`table_schema`,a.`table_name`,a.`index_name`,a.`index_columns`,b.`index_name`,b.`index_columns`,concat('ALTER TABLE `',a.`table_schema`,'`.`',a.`table_name`,'` DROP INDEX `',a.`index_name`,'`') from ((select `information_schema`.`statistics`.`TABLE_SCHEMA` AS `table_schema`,`information_schema`.`statistics`.`TABLE_NAME` AS `table_name`,`information_schema`.`statistics`.`INDEX_NAME` AS `index_name`,max(`information_schema`.`statistics`.`NON_UNIQUE`) AS `non_unique`,max(if(isnull(`information_schema`.`statistics`.`SUB_PART`),0,1)) AS `subpart_exists`,group_concat(`information_schema`.`statistics`.`COLUMN_NAME` order by `information_schema`.`statistics`.`SEQ_IN_INDEX` ASC separator ',') AS `index_columns` from `information_schema`.`statistics` where ((`information_schema`.`statistics`.`INDEX_TYPE` = 'BTREE') and (`information_schema`.`statistics`.`TABLE_SCHEMA` not in ('mysql','sys','INFORMATION_SCHEMA','PERFORMANCE_SCHEMA'))) group by `information_schema`.`statistics`.`TABLE_SCHEMA`,`information_schema`.`statistics`.`TABLE_NAME`,`information_schema`.`statistics`.`INDEX_NAME`) a join (select `information_schema`.`statistics`.`TABLE_SCHEMA` AS `table_schema`,`information_schema`.`statistics`.`TABLE_NAME` AS `table_name`,`information_schema`.`statistics`.`INDEX_NAME` AS `index_name`,max(`information_schema`.`statistics`.`NON_UNIQUE`) AS `non_unique`,max(if(isnull(`information_schema`.`statistics`.`SUB_PART`),0,1)) AS `subpart_exists`,group_concat(`information_schema`.`statistics`.`COLUMN_NAME` order by `information_schema`.`statistics`.`SEQ_IN_INDEX` ASC separator ',') AS `index_columns` from `information_schema`.`statistics` where ((`information_schema`.`statistics`.`INDEX_TYPE` = 'BTREE') and (`information_schema`.`statistics`.`TABLE_SCHEMA` not in ('mysql','sys','INFORMATION_SCHEMA','PERFORMANCE_SCHEMA'))) group by `information_schema`.`statistics`.`TABLE_SCHEMA`,`information_schema`.`statistics`.`TABLE_NAME`,`information_schema`.`statistics`.`INDEX_NAME`) b on(((a.`table_schema` = b.`table_schema`) and (a.`table_name` = b.`table_name`)))) where ((a.`index_name` <> b.`index_name`) and (((a.`index_columns` = b.`index_columns`) and ((a.`non_unique` > b.`non_unique`) or ((a.`non_unique` = b.`non_unique`) and (if((a.`index_name` = 'PRIMARY'),'',a.`index_name`) > if((b.`index_name` = 'PRIMARY'),'',b.`index_name`))))) or ((locate(concat(a.`index_columns`,','),b.`index_columns`) = 1) and (a.`non_unique` = 1)) or ((locate(concat(b.`index_columns`,','),a.`index_columns`) = 1) and (b.`non_unique` = 0))));

查詢未使用過的索引

select `information_schema`.`statistics`.`TABLE_SCHEMA` AS `table_schema`,`information_schema`.`statistics`.`TABLE_NAME` AS `table_name`,`information_schema`.`statistics`.`INDEX_NAME` AS `index_name`,max(`information_schema`.`statistics`.`NON_UNIQUE`) AS `non_unique`,max(if(isnull(`information_schema`.`statistics`.`SUB_PART`),0,1)) AS `subpart_exists`,group_concat(`information_schema`.`statistics`.`COLUMN_NAME` order by `information_schema`.`statistics`.`SEQ_IN_INDEX` ASC separator ',') AS `index_columns` from `information_schema`.`statistics` where ((`information_schema`.`statistics`.`INDEX_TYPE` = 'BTREE') and (`information_schema`.`statistics`.`TABLE_SCHEMA` not in ('mysql','sys','INFORMATION_SCHEMA','PERFORMANCE_SCHEMA'))) group by `information_schema`.`statistics`.`TABLE_SCHEMA`,`information_schema`.`statistics`.`TABLE_NAME`,`information_schema`.`statistics`.`INDEX_NAME`

補充:mysql ID 取余索引_mysql重復索引、冗余索引、未使用索引的定義和查找

1.冗余和重復索引

mysql允許在相同列上創(chuàng)建多個索引,無論是有意還是無意,mysql需要單獨維護重復的索引,并且優(yōu)化器在優(yōu)化查詢的時候也需要逐個地進行考慮,這會影響性能。重復索引是指的在相同的列上按照相同的順序創(chuàng)建的相同類型的索引,應該避免這樣創(chuàng)建重復所以,發(fā)現以后也應該立即刪除。但,在相同的列上創(chuàng)建不同類型的索引來滿足不同的查詢需求是可以的。

冗余索引和重復索引有一些不同,如果創(chuàng)建了索引(a,b),再創(chuàng)建索引(a)就是冗余索引,因為這只是前面一個索引的前綴索引,因此(a,b)也可以當作(a)來使用,但是(b,a)就不是冗余索引,索引(b)也不是,因為b不是索引(a,b)的最左前綴列,另外,其他不同類型的索引在相同列上創(chuàng)建(如哈希索引和全文索引)不會是btree索引的冗余索引。

另外:對于二級索引(a,id),id是主鍵,對于innodb來說,主鍵列已經包含在二級索引中了,所以這個也是冗余索引。大多數情況下都不需要冗余索引,應該盡量擴展已有的索引而不是創(chuàng)建新索引,但也有時候處于性能方面的考慮需要冗余索引,因為擴展已有的索引會導致其變得太大,從而影響其他使用該索引的查詢性能。如:如果在整數列上有一個索引,現在需要額外增加一個很長的varchar列來擴展該索引,那么性可能會急劇下降,特別是有查詢把這個索引當作覆蓋索引,或者這是myisam表并且有很多范圍查詢的時候(由于myisam的前綴壓縮)。

如:表userinfo,myisam引擎,有100W行記錄,每個state_id值大概2W行,在state_id列有一個索引對下面的查詢有用:如:select count(*) from userinfo where state_id=5;測試每秒115次QPS

對于下面的查詢這個state_id列的索引就不太頂用了,每秒QPS是10次

select state_id,city,address from userinfo where state_id=5;

如果把state_id索引擴展為(state_id,city,address),那么第二個查詢的性能更快了,但是第一個查詢卻變慢了,如果要兩個查詢都快,那么就必須要把state_id列索引進行冗余了。但如果是innodb表,不冗余state_id列索引對第一個查詢的影響并不明顯,因為innodb沒有使用索引壓縮,myisam和innmodb表使用不同的索引策略的select查詢的qps測試結果(以下測試數據僅供參考):

只有state_id列索引 只有state_id_2索引 同時有兩個索引

myisam,第一個查詢 114.96 25.40 112.19

myisam,第二個查詢 9.97 16.34 16.37

innodb,第一個查詢 108.55 100.33 107.97

innodb,第二個查詢 12.12 28.04 28.06

從上圖中可以看出,兩個索引都有的時候,缺點是成本更高,下面是在不同的索引策略時插入innodb和myisam表100W行數據的速度(以下測試數據僅供參考):

只有state_id列索引 同時有兩個索引

innodb,對有兩個索引都有足夠的內容的時候 80秒 136秒

myisam,只有一個索引有足夠的內容的時候 72秒 470秒

可以看到,不論什么引擎,索引越多,插入速度越慢,特別是新增索引后導致達到了內存瓶頸的時候。解決冗余索引和重復索引的方法很簡單,刪除這些索引就可以了,但首先要做的是找出這樣的索引,可以通過一些復雜的訪問information_schema表的查詢來找,不過還有兩個更簡單的方法,使用:shlomi noach的common_schema中的一些視圖來定位,也可以使用percona toolkit中的pt-dupulicate-key-checker工具,該工具通過分析表結構來找出冗余和重復的索引,對于大型服務器來說,使用外部的工具更合適,如果服務器上有大量的數據或者大量的表,查詢information_schema表可能會導致性能問題。建議使用pt-dupulicate-key-checker工具。

在刪除索引的時候要非常小心:

如果在innodb引擎表上有where a=5 order by id這樣的查詢,那么索引(a)就會很有用,索引(a,b)實際上是(a,b,id)索引,這個索引對于where a=5 order by id這樣的查詢就無法使用索引做排序,而只能使用文件排序了。所以,建議使用percona工具箱中的pt-upgrade工具來仔細檢查計劃中的索引變更。

2. 未使用的索引

除了冗余索引和重復索引,可能還會有一些服務器永遠不使用的索引,這樣的索引完全是累贅,建議考慮刪除,有兩個工具可以幫助定位未使用的索引:

A:在percona server或者mariadb中先打開userstat=ON服務器變量,默認是關閉的,然后讓服務器運行一段時間,再通過查詢information_schema.index_statistics就能查到每個索引的使用頻率。

B:使用percona toolkit中的pt-index-usage工具,該工具可以讀取查詢日志,并對日志中的每個查詢進行explain操作,然后打印出關羽索引和查詢的報告,這個工具不僅可以找出哪些索引是未使用的,還可以了解查詢的執(zhí)行計劃,如:在某些情況下有些類似的查詢的執(zhí)行方式不一樣,這可以幫助定位到那些偶爾服務器質量差的查詢,該工具也可以將結果寫入到mysql的表中,方便查詢結果。

以上為個人經驗,希望能給大家一個參考,也希望大家多多支持腳本之家。如有錯誤或未考慮完全的地方,望不吝賜教。

相關文章

  • Windows下mysql?8.0.29?winx64安裝配置方法圖文教程

    Windows下mysql?8.0.29?winx64安裝配置方法圖文教程

    這篇文章主要為大家詳細介紹了Windows下mysql?8.0.29?winx64安裝配置方法圖文教程,文中安裝步驟介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-07-07
  • MySQL MHA 運行狀態(tài)監(jiān)控介紹

    MySQL MHA 運行狀態(tài)監(jiān)控介紹

    這篇文章主要介紹MySQL MHA 運行狀態(tài)監(jiān)控,MHA(Master HA)是一款開源的 MySQL 的高可用程序,它為 MySQL 主從復制架構提供了 automating master failover 功能,想具體了解的小伙伴可以和小編一起學習下面文章內容
    2021-10-10
  • Python MySQL進行數據庫表變更和查詢

    Python MySQL進行數據庫表變更和查詢

    這篇文章主要介紹了Python MySQL進行數據庫表變更和查詢的相關資料,需要的朋友可以參考下
    2017-05-05
  • MySQL深入詳解delete與Truncate及drop的使用區(qū)別

    MySQL深入詳解delete與Truncate及drop的使用區(qū)別

    對于drop、truncate和delete雖然簡單,但是真要使用或者面試時候問到還是需要有一定的總結,下面這篇文章主要給大家介紹了關于mysql中drop、truncate與delete區(qū)別的相關資料,需要的朋友可以參考下
    2022-07-07
  • MySQL系統庫之performance_schema的實現

    MySQL系統庫之performance_schema的實現

    performance_schema用于收集和存儲關于數據庫性能和資源利用情況的信息,本文主要介紹了MySQL系統庫之performance_schema的實現,具有一定的參考價值,感興趣的可以了解一下
    2023-11-11
  • 詳解MySql中InnoDB存儲引擎中的各種鎖

    詳解MySql中InnoDB存儲引擎中的各種鎖

    本文主要介紹了詳解MySql中InnoDB存儲引擎中的各種鎖,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-02-02
  • MySQL中獲取當前時間格式的方法匯總

    MySQL中獲取當前時間格式的方法匯總

    在MySQL數據庫開發(fā)中,獲取時間是一個常見的需求,MySQL提供了多種方法來獲取當前日期、時間和時間戳,并且可以對時間進行格式化、計算和轉換,以下是一些常用的MySQL時間函數及其示例,需要的朋友可以參考下
    2024-06-06
  • 在centos7下安裝和部署java8和mysql

    在centos7下安裝和部署java8和mysql

    一般學習java和部署項目都是在本地部署,但是生產環(huán)境一般都是在linux環(huán)境下,部署和安裝環(huán)境都是在控制臺下進行操作的,沒有windows的可視化的操作界面,對與linux的命令掌握和操作對小白來說都是一個個挑戰(zhàn),記錄下自己的安裝配置過程
    2017-04-04
  • Mysql提升大數據表拷貝效率的解決方案

    Mysql提升大數據表拷貝效率的解決方案

    這篇文章主要給大家介紹了關于Mysql提升大數據表拷貝效率的解決方案,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧
    2018-09-09
  • MYSQL 關于兩個經緯度之間的距離由近及遠排序

    MYSQL 關于兩個經緯度之間的距離由近及遠排序

    本篇文章是對MYSQL中關于兩個經緯度之間的距離由近及遠排序的方法進行了詳細的分析介紹,需要的朋友參考下
    2013-07-07

最新評論