国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 數據庫 > 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教程頻道。
發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 雅安市| 洛南县| 铜川市| 塘沽区| 长治县| 漯河市| 吉木萨尔县| 民丰县| 辽阳县| 泊头市| 阳城县| 西丰县| 巴楚县| 长丰县| 肇源县| 昌图县| 江陵县| 扎赉特旗| 清涧县| 金寨县| 襄城县| 重庆市| 扎赉特旗| 江阴市| 新丰县| 九寨沟县| 甘德县| 门源| 汽车| 德令哈市| 谷城县| 曲周县| 正蓝旗| 丹寨县| 陵川县| 常熟市| 甘南县| 平和县| 孟津县| 新邵县| 陵川县|