MySQL隐形索引简介
不可见索引允许您将索引标记为查询优化器不可用。MySQL维护不可见索引,并在与索引关联的列中的数据发生更改时使其保持最新。
默认情况下,索引是可见的。要使它们不可见,您必须在创建时或使用ALTER TABLE命令显式声明其可见性。MySQL为我们提供了维护索引可见性的关键字VISIBLE和INVISIBLE关键字。
要创建不可见索引,请使用以下语句:
|
1
2
|
CREATE INDEX index_name
ON table_name( c1, c2, ...) INVISIBLE;
|
在这个语法中:
- 首先,在
CREATE INDEX子句后指定索引的名称。 - 其次,列出要添加到索引的表名和列列表。该
INVISIBLE关键字表明您正在创建的索引是不可见的。
例如,以下语句在示例数据库extension中的employees表的列上创建索引,并将其标记为不可见索引:
|
1
2
|
CREATE INDEX extension
ON employees(extension) INVISIBLE;
|
要更改现有索引的可见性,请使用以下语句:
|
1
2
|
ALTER TABLE table_name
ALTER INDEX index_name [VISIBLE | INVISIBLE];
|
例如,要使extension索引可见,请使用以下语句:
|
1
2
|
ALTER TABLE employees
ALTER INDEX extension VISIBLE;
|
您可以通过查询数据库中的statistics表来查找索引及其可见性information_schema:
|
1
2
3
4
5
6
7
8
|
SELECT
index_name,
is_visible
FROM
information_schema.statistics
WHERE
table_schema = 'classicmodels'
AND table_name = 'employees';
|
这是输出:

此外,您可以使用该SHOW INDEXES命令显示表的所有索引:
|
1
|
SHOW INDEXES FROM employees;
|
如前所述,查询优化器不使用不可见索引,那么为什么首先使用不可见索引?实际上,隐形索引有许多应用程序。例如,您可以使索引不可见,以查看它是否对性能产生影响,并将索引再次标记为可见。
MySQL隐形索引和主键
主键列上的索引不能是不可见的。如果您尝试这样做,MySQL将发出错误。
此外,隐式主键索引也不可见。当您UNIQUE在NOT NULL没有主键的表的列上定义索引时,MySQL会隐式地理解该列是主键列,并且不允许您使索引不可见。
请考虑以下示例。
首先,创建一个新表与UNIQUE上一个索引NOT NULL列:
|
1
2
3
4
5
6
7
8
|
CREATE TABLE discounts (
discount_id INT NOT NULL,
name VARCHAR(50) NOT NULL,
valid_from DATE NOT NULL,
valid_to DATE NOT NULL,
amount DEC(5 , 2 ) NOT NULL DEFAULT 0,
UNIQUE discount_id(discount_id)
);
|
其次,尝试使discount_id 索引不可见:
|
1
2
|
ALTER TABLE discounts
ALTER INDEX discount_id INVISIBLE;
|
MySQL发出以下错误消息:
|
1
|
Error Code: 3522. A primary key index cannot be invisible
|
MySQL隐形索引系统变量
为了控制查询优化器使用的可见索引,MySQL使用系统变量的use_invisible_indexes标志optimizer_switch。默认情况下,use_invisible_indexes关闭:
|
1
|
SELECT @@optimizer_switch;
|
在本教程中,您了解了MySQL隐形索引,如何创建
MySQL隐形索引简介的更多相关文章
- MySQL数据库索引简介
一.索引的含义和特点 索引是一个单独的.存储在磁盘上的数据库结构,他们包含着对数据表里所有记录的引用指针.使用索引用于快速找出某个或多个列中有一特点值的行,所用MySQL列类型都可以被索引,对 ...
- mysql之索引简介
索引分类 mysql在存储数据时,是按着主键的顺序存储的.主键索引是物理索引,其他索引都是逻辑索引. 普通索引 普通索引是最基本的索引,没有任何限制的索引,普通索引列的数据可以重复.其唯一的任务就是加 ...
- 【Mysql】索引简介
本文口味:番茄炒蛋,预计阅读:10分钟. 博客又停更了两个月,在这期间,对人生和世界多了许多思考.在人生的不同阶段,会对生活和世界有着不一样的认知,而认知的改变也会直接反应在行为模式之中. 对于生活的 ...
- 【mysql】- 索引简介篇
简介 我们都知道mysql使用存储引擎的是InnoDB,InnoDB使用的索引的对应的数据结构是B+树 结构图: 如上图所示,我们实际用户记录是存放在B+树的最底层的节点上,这些节点也被称为叶子节点或 ...
- MySQL中的索引简介
MySQL中的SQL的常见优化策略 MySQL中的索引优化 MySQL中的索引简介 一. 索引的优点 为什么要创建索引?这是因为,创建索引可以大大提高系统的查询性能. 第一.通过创建唯一性索引,可以保 ...
- 第 3 章 MySQL 存储引擎简介
第 3 章 MySQL 存储引擎简介 前言 3.1 MySQL 存储引擎概述 MyISAM 存储引擎是 MySQL 默认的存储引擎,也是目前 MySQL 使用最为广泛的存储引擎之一.他的前身就是我们在 ...
- MySQL(3)-索引
一.索引类型 在MySQL中,存储引擎使用索引,首先在索引中找到对应值,然后根据匹配的索引记录中找到对应的行. 无论是多么复杂的ORM工具,在精妙和复杂的索引面前都是"浮云".这里 ...
- 为什么MySQL数据库索引选择使用B+树?
在进一步分析为什么MySQL数据库索引选择使用B+树之前,我相信很多小伙伴对数据结构中的树还是有些许模糊的,因此我们由浅入深一步步探讨树的演进过程,在一步步引出B树以及为什么MySQL数据库索引选择使 ...
- MySQL慢日志简介及Anemometer工具介绍
作者:王航威 - fordba.com 来源:http://fordba.com/box-anemometer-visual-mysql-slow.html,叶师傅对原文内容略有调整 备注:王航威是知 ...
随机推荐
- Linux信号和trap命令的使用
目录 信号介绍 信号列表 控制信号 Ctrl+c显示指定内容 使Ctrl+c无任何操作 处理多个信号 处理所有信号 恢复信号 实现跳板机(实例) 信号介绍 运行Shell脚本时,如果按下快捷键Ctrl ...
- C# 1.0 到 4.0 的进化 1
定义一个产品类 Product C# 1 using System; using System.Collections; namespace C1 { public class Product { s ...
- vi/vim编辑器必知必会
一.我们为什么要学习vim编辑器? Linux的命令行界面下面有非常多的文本编辑器.比如经常听说的就有Emacs.pico.nano.joe与vim等.vim可以看做是vi的高级版.我们为什么一定要学 ...
- ibatis in的用法
<dynamic-mapped-statement name="queryLabelservicecodeLogSize" result-class="java.l ...
- BeanDefinition到Bean
转自:http://songzi0206.iteye.com/blog/1430239 当 BeanDefinition 注册完毕以后, Spring Bean 工厂就可以随时根据需要进行实例化了.对 ...
- 程序员必知的8大排序(四)-------归并排序,基数排序(java实现)
程序员必知的8大排序(一)-------直接插入排序,希尔排序(java实现) 程序员必知的8大排序(二)-------简单选择排序,堆排序(java实现) 程序员必知的8大排序(三)-------冒 ...
- Django models 的常用字段类型和字段参数
<1> CharField #字符串字段, 用于较短的字符串. #CharField 要求必须有一个参数 maxlength, 用于从数据库层和Django校验层限制该字段所允许的最大字符 ...
- UVa 442 Matrix Chain Multiplication(栈的应用)
题目链接: https://cn.vjudge.net/problem/UVA-442 /* 问题 输入有括号表示优先级的矩阵链乘式子,计算该式进行的乘法次数之和 解题思路 栈的应用,直接忽视左括号, ...
- gulp自动添加版本号过程中的一些要点记录
1.打开node_modules\gulp-rev\index.js 第144行 manifest[originalFile] = revisionedFile; 更新为: manifest[orig ...
- JS DOM操作(四) Window.docunment对象——操作内容
操作内容:即对标签所夹内容的操作 一 非表单元素内容操作 定位 var a = document.ElementById( "id" ) 1.获取内容 var s = a.inne ...