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

首頁 > 數據庫 > MySQL > 正文

MySQL 8 新特性之Invisible Indexes

2024-07-25 19:08:22
字體:
來源:轉載
供稿:網友

背景

索引是把雙刃劍,在提升查詢速度的同時會減慢DML的操作。畢竟,索引的維護需要一定的成本。所以,對于索引,要加上該加的,刪除無用的。前者是加法,后者是減法。但在實際工作中,大家似乎更熱衷于前者,而很少進行后者。究其原因,在于后者,難。難的不是操作本身,而是如何確認一個索引是無用的。

如何確認無用索引

在不可見索引出現之前,大家可以通過sys.schema_unused_indexes來確定無用索引。在MySQL 5.6中,即使沒有sys庫,也可通過該視圖的基表來進行查詢。

mysql> show create table sys.schema_unused_indexes/G*************************** 1. row ***************************        View: schema_unused_indexes    Create View: CREATE ALGORITHM=MERGE DEFINER=`mysql.sys`@`localhost` SQL SECURITY INVOKER VIEW `sys`.`schema_unused_indexes` (`object_schema`,`object_name`,`index_name`) AS select `t`.`OBJECT_SCHEMA` AS `object_schema`,`t`.`OBJECT_NAME` AS `object_name`,`t`.`INDEX_NAME` AS `index_name` from (`performance_schema`.`table_io_waits_summary_by_index_usage` `t` join `information_schema`.`STATISTICS` `s` on(((`t`.`OBJECT_SCHEMA` = convert(`s`.`TABLE_SCHEMA` using utf8mb4)) and (`t`.`OBJECT_NAME` = convert(`s`.`TABLE_NAME` using utf8mb4)) and (convert(`t`.`INDEX_NAME` using utf8) = `s`.`INDEX_NAME`)))) where ((`t`.`INDEX_NAME` is not null) and (`t`.`COUNT_STAR` = 0) and (`t`.`OBJECT_SCHEMA` <> 'mysql') and (`t`.`INDEX_NAME` <> 'PRIMARY') and (`s`.`NON_UNIQUE` = 1) and (`s`.`SEQ_IN_INDEX` = 1)) order by `t`.`OBJECT_SCHEMA`,`t`.`OBJECT_NAME`character_set_client: utf8mb4collation_connection: utf8mb4_0900_ai_ci1 row in set, 1 warning (0.00 sec)

但這種方式也有不足,

1. 如果實例發生重啟,performance_schema中的數據就會清零。

2. 如果基于上面的查詢刪除了索引,查詢性能突然變差,怎么辦?

不可見索引的出現,可有效彌補上述不足。將index設置為invisible,會導致優化器在選擇執行計劃時,自動忽略該索引,即便使用了FORCE INDEX。

當然,這個是由optimizer_switch變量中use_invisible_indexes選項決定的,默認為off。如果想看一個查詢在索引調整前后執行計劃的差別,可在會話級別調整use_invisible_indexes的值,如,

mysql> show create table slowtech.t1/G*************************** 1. row ***************************   Table: t1Create Table: CREATE TABLE `t1` ( `id` int(11) NOT NULL, `name` varchar(10) DEFAULT NULL, PRIMARY KEY (`id`), KEY `idx_name` (`name`) /*!80000 INVISIBLE */) ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COLLATE=utf8mb4_0900_ai_ci1 row in set (0.00 sec)mysql> explain select * from slowtech.t1 where name='a';+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------------+| id | select_type | table | partitions | type | possible_keys | key | key_len | ref | rows | filtered | Extra   |+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------------+| 1 | SIMPLE   | t1  | NULL   | ALL | NULL     | NULL | NULL  | NULL |  6 |  16.67 | Using where |+----+-------------+-------+------------+------+---------------+------+---------+------+------+----------+-------------+1 row in set, 1 warning (0.00 sec)mysql> set session optimizer_switch="use_invisible_indexes=on";Query OK, 0 rows affected (0.00 sec)mysql> explain select * from slowtech.t1 where name='a';+----+-------------+-------+------------+------+---------------+----------+---------+-------+------+----------+-------------+| id | select_type | table | partitions | type | possible_keys | key   | key_len | ref | rows | filtered | Extra   |+----+-------------+-------+------------+------+---------------+----------+---------+-------+------+----------+-------------+| 1 | SIMPLE   | t1  | NULL   | ref | idx_name   | idx_name | 43   | const |  1 | 100.00 | Using index |+----+-------------+-------+------------+------+---------------+----------+---------+-------+------+----------+-------------+1 row in set, 1 warning (0.00 sec)

不可見索引的常見操作

create table t1(id int primary key,name varchar(10),index idx_name (name) invisible);alter table t1 alter index idx_name visible;alter table t1 alter index idx_name invisible;

如何查看哪些索引不可見

mysql> select table_schema,table_name,index_name,column_name,is_visible from information_schema.statistics where is_visible='no';+--------------+------------+------------+-------------+------------+| TABLE_SCHEMA | TABLE_NAME | INDEX_NAME | COLUMN_NAME | IS_VISIBLE |+--------------+------------+------------+-------------+------------+| slowtech  | t1    | idx_name | name    | NO    |+--------------+------------+------------+-------------+------------+1 row in set (0.00 sec)

注意

1. 主鍵索引不可被設置為invisible。

總結

以上所述是小編給大家介紹的MySQL 8 新特性之Invisible Indexes ,希望對大家有所幫助,如果大家有任何疑問歡迎給我留言,小編會及時回復大家的!


注:相關教程知識閱讀請移步到MYSQL教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
亚洲欧美激情视频| 欧美性猛交丰臀xxxxx网站| 国产精品久久99久久| 国产精品色婷婷视频| 免费97视频在线精品国自产拍| 人人澡人人澡人人看欧美| 亚洲日韩第一页| 国产aⅴ夜夜欢一区二区三区| 国内精品久久久久久中文字幕| 韩国国内大量揄拍精品视频| 91亚洲精品在线观看| 国产精品自产拍在线观看中文| 2019中文字幕在线| 91精品视频大全| 成人免费视频网址| 日本不卡视频在线播放| 亚洲天堂av在线播放| 2019中文字幕免费视频| 久久免费视频这里只有精品| 亚洲精品美女久久| 久久精品这里热有精品| 日韩在线视频中文字幕| 久久久久久久激情视频| 国内精品伊人久久| 国产999精品久久久| 亚洲午夜色婷婷在线| 久久久久久久久久久av| 久久精品国产亚洲精品| 日本不卡视频在线播放| 成人在线国产精品| 久久久久久91香蕉国产| 久久久亚洲影院| 久久午夜a级毛片| 日韩亚洲在线观看| 国产精品福利在线观看网址| 日韩美女视频免费在线观看| 国产精品情侣自拍| 精品亚洲国产成av人片传媒| 伊人久久大香线蕉av一区二区| 深夜福利国产精品| 成人激情免费在线| 国产精品大片wwwwww| 中文字幕亚洲情99在线| 亚洲va欧美va国产综合剧情| 日韩有码视频在线| 亚洲国产福利在线| 亚洲精品99久久久久| 精品国产一区二区三区四区在线观看| 日本国产精品视频| 日韩精品一区二区三区第95| 欧美尤物巨大精品爽| 亚洲国产97在线精品一区| 亚洲国产天堂久久综合网| 国产日韩精品在线| 久久影院模特热| 国产午夜精品视频免费不卡69堂| 亚洲电影av在线| 俺也去精品视频在线观看| 88国产精品欧美一区二区三区| 欧美成人剧情片在线观看| 欧美午夜激情小视频| 另类天堂视频在线观看| 亚州精品天堂中文字幕| 久久久久久国产免费| 国产在线视频2019最新视频| 国产美女久久精品香蕉69| 欧美自拍视频在线| 国产精品久久9| 日韩精品免费视频| 亚洲图片制服诱惑| 中文字幕精品www乱入免费视频| 欧美精品亚州精品| 国产精品一区二区在线| 91欧美视频网站| 亚洲国产精品va在线| 国产精品久久97| 亚洲国产另类 国产精品国产免费| 国产福利视频一区二区| 91成人在线播放| 青青草原一区二区| 精品国产91久久久久久| 久久久久久久久爱| 久久久久久999| 中文日韩在线视频| 国产亚洲精品久久| 成人亚洲激情网| 一区二区三区日韩在线| 韩曰欧美视频免费观看| 成人免费激情视频| 欧美日韩免费看| 欧美www视频在线观看| 久久av在线看| 日韩在线观看网址| 97激碰免费视频| 国产精品日韩欧美大师| 青草成人免费视频| 日韩美女视频在线观看| 45www国产精品网站| 亚洲美女久久久| 欧美巨乳在线观看| 成人福利视频在线观看| 国产不卡av在线免费观看| 精品国产欧美一区二区三区成人| 欧美国产日韩免费| 精品亚洲精品福利线在观看| 亚洲码在线观看| 欧美激情视频三区| 色一区av在线| 91av在线播放| 久久午夜a级毛片| 欧美综合国产精品久久丁香| 欧美性极品xxxx娇小| 日韩电影免费观看中文字幕| 欧美成人精品三级在线观看| 亚洲一区二区三区四区视频| 69**夜色精品国产69乱| 国产欧美最新羞羞视频在线观看| 亚洲一区二区三区久久| 国产va免费精品高清在线观看| 欧美视频在线观看免费| 欧美一性一乱一交一视频| 国产精品a久久久久久| 欧美日韩亚洲系列| 色妞久久福利网| 久久久电影免费观看完整版| 热门国产精品亚洲第一区在线| 国产精品网址在线| 精品视频—区二区三区免费| 日韩欧美高清视频| 波霸ol色综合久久| 日本精品性网站在线观看| 在线视频欧美日韩| 欧美黑人xxxx| 亚洲一区免费网站| 欧美电影免费观看大全| 国产啪精品视频网站| 久久的精品视频| 日韩视频在线免费观看| 久久亚洲影音av资源网| 久久久久久国产精品| 欧美日韩国产页| 人妖精品videosex性欧美| 一二美女精品欧洲| 欧美老妇交乱视频| 亚洲天堂男人天堂女人天堂| 亚洲国产日韩精品在线| 日韩中文字幕在线看| 最近中文字幕日韩精品| 人人做人人澡人人爽欧美| 国产成人综合久久| 国产精品视频在线观看| 亚洲一级黄色片| 国产精品爽黄69天堂a| 色视频www在线播放国产成人| 国产伊人精品在线| 久久亚洲精品国产亚洲老地址| 爽爽爽爽爽爽爽成人免费观看| 欧美亚洲激情在线| 国产精品久久久久国产a级| 日韩精品高清在线| 国产成人激情视频| 色多多国产成人永久免费网站| 久久久久亚洲精品| 中文字幕亚洲无线码a|