- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章MySQL 8 新特性之Invisible Indexes由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
背景 。
索引是把双刃剑,在提升查询速度的同时会减慢DML的操作。毕竟,索引的维护需要一定的成本。所以,对于索引,要加上该加的,删除无用的。前者是加法,后者是减法。但在实际工作中,大家似乎更热衷于前者,而很少进行后者。究其原因,在于后者,难。难的不是操作本身,而是如何确认一个索引是无用的.
如何确认无用索引 。
在不可见索引出现之前,大家可以通过sys.schema_unused_indexes来确定无用索引。在MySQL 5.6中,即使没有sys库,也可通过该视图的基表来进行查询.
1
2
3
4
5
6
7
|
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: utf8mb4
collation_connection: utf8mb4_0900_ai_ci
1 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的值,如, 。
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
mysql> show create table slowtech.t1\G
***************************
1
. row ***************************
Table: t1
Create 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_ci
1
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)
|
不可见索引的常见操作 。
1
2
3
|
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;
|
如何查看哪些索引不可见 。
1
2
3
4
5
6
7
|
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 ,希望对大家有所帮助,如果大家有任何疑问欢迎给我留言,小编会及时回复大家的! 。
原文链接:https://www.cnblogs.com/ivictor/p/8998797.html 。
最后此篇关于MySQL 8 新特性之Invisible Indexes的文章就讲到这里了,如果你想了解更多关于MySQL 8 新特性之Invisible Indexes的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
这个问题已经有答案了: 已关闭14 年前。 ** 重复:What's the difference between X = X++; vs X++;? ** 所以,即使我知道你永远不会在代码中真正做到
我在一本C语言的书上找到了这个例子。此代码转换输入数字基数并将其存储在数组中。 #include int main(void) { const char base_digits[16] =
尝试使用“pdf_dart”库保存 pdf 时遇到问题。 我认为问题与我从互联网下载以尝试附加到 pdf 的图像有关,但我不确定它是什么。 代码 import 'dart:io'; import 'p
我的 Apache 服务器曾经可以正常工作,但它随机开始对几乎每个目录发出 403 错误。两个目录仍然有效,我怎样才能使/srv/www/htdocs 中的所有目录正常工作? 我查看了两个可用目录的权
这些索引到 PHP 数组的方法之间有什么区别(如果有的话): $array[$index] $array["$index"] $array["{$index}"] 我对性能和功能上的差异都感兴趣。 更
我有一个简单的结构,我想为其实现 Index,但作为 Rust 的新手,我在借用检查器方面遇到了很多麻烦。我的结构非常简单,我想让它存储一个开始值和步长值,然后当被 usize 索引时它应该返回 st
我对 MarkLogic 中的 element-range-index 和 field-range-index 感到困惑。 请借助示例来解释差异。 最佳答案 这两个都是标量索引:特定类型的基于值的排序
我对 MarkLogic 中的 element-range-index 和 field-range-index 感到困惑。 请借助示例来解释差异。 最佳答案 这两个都是标量索引:特定类型的基于值的排序
所以我有一个 df,我在其中提取一个值以将其存储在另一个 df 中: import pandas as pd # Create data set d = {'foo':[100, 111, 222],
我有一个由 codeigniter 编写的网站,我已经通过 htaccess 从地址中删除了 index.php RewriteCond $1 !^(index\.php|resources|robo
谁能告诉我这两者有什么区别: ALTER TABLE x1 ADD INDEX(a); ALTER TABLE x1 ADD INDEX(b); 和 ALTER TABLE x1 ADD INDEX(
我在 Firefox 和其他浏览器上遇到嵌套 z-index 的问题,我有一个 div,z-index 为 30000,位于 label 下方> zindex 为 9000。我认为这是由 z-inde
Link to the function image编写了一个函数来查找中枢元素(起始/最低)的索引 排序和旋转数组。我解决了这个问题并正在检查 边缘情况,它甚至适用于索引为零的情况。任何人都可以 解
我正在尝试运行有关成人人口普查数据的示例代码。当我运行这段代码时: X_train, X_test, y_train, y_test = cross_validation.train_test_spl
我最近将我的 index.html 更改为 index.php - 我希望能够进行重定向以反射(reflect)这一点,然后还进行重写以强制 foo.com/index.php 成为 foo.com/
我最近将我的 index.html 更改为 index.php - 我希望能够进行重定向以反射(reflect)这一点,然后还进行重写以强制 foo.com/index.php 成为 foo.com/
我有一个用户定义的函数,如下所示:- def genre(option,option_type,*limit): option_based = rank_data.loc[rank_data[
我有两个巨大的数据框我正在合并它们,但我不想有重复的列,因此我通过减去它们来选择列: cols_to_use=df_fin.columns-df_peers.columns.difference(['
感谢您从现在开始的回答, 我是React Native的新手,我想做一个跨平台的应用所以我创建了index.js: import React from 'react'; import { Co
我知道 not_analyzed 是什么意思。简而言之,该字段不会被指定的分析器标记化。 然而,什么是 NO_NORMS 方法?我看到了文档,但请用简单的英语解释我。什么是索引时间字段和文档提升和字段
我是一名优秀的程序员,十分优秀!