1. 索引简介

  索引是一种特殊的数据库结构,可以用来快速查询数据中的特定记录。

  MySQL中索引包括:普通索引、唯一性索引、全文索引、单列索引、多列索引和空间索引等。

1.1 索引定义

  索引由数据库表中一列或多列组合而成,作用是提高对表中数据的查询速度。

  索引是创建在表是的,对数据表中一列或多列的值进行排序的一种结构。

  MySQL索引包含两种存储类型:BTREE索引和HASH索引。InnoDB和MyISAM存储引擎支持BTREE索引,MEMORY存储引擎支持HASH索引和BTREE索引,默认为HASH索引。

  索引的优点:可以提高检索数据的速度。

  索引的缺点:创建和维护索引需要耗费时间,耗费的时间随数据量增加而增加;

        索引需要占用物理空间,每一个索引要占一定的物理空间;

        增加、删除和修改数据时,要动态维护索引,降低数据维护速度。

  索引可以提高查询的速度,但会影响插入记录的速度。向有索引的表中插入记录时,数据库系统会按照索引进行排序。

  插入大量记录时,最好的办法是先删除表中的索引,再插入数据,插入完成后,再创建索引。

1.2 索引分类

  MySQL中索引包括:普通索引、唯一性索引、全文索引、单列索引、多列索引和空间索引等。

  1>. 普通索引

  在创建普通索引时,不附加任何限制条件。

  2>. 唯一性索引

  使用UNIQUE设置唯一性索引。在创建唯一性索引时,限制该索引的值必须是唯一的。

  唯一性索引,可以更快地确定某条记录。

  主键是一种特殊的唯一性索引。

  3>. 全文索引

  使用FULLTEXT设置索引为全文索引。全文索引只能创建在CHAR、VARCHAR或TEXT类型的字段上。

  查询数据量较大的字符串类型的字段时,使用全文索引可以提高查询速度。

  只有MyISAM存储引擎支持全文索引。

  4>. 单列索引

  

1.3 索引设计原则

  (1)索引并非越多越好,一个表中如有大量的索引,占用磁盘空间,影响INSERT、UPDATE、DELETE等语句性能。

  (2)避免对经常更新的表进行过多的索引,索引中的列尽可能少。

  (3)数据量小的表最好不要使用索引。

  (4)在条件表达式中经常用到的不同值较多的列上创建索引,在不同值较少的列上不要创建索引。如:性别字段只有“男”和“女”两个不同值,无须创建索引。

  (5)当唯一性是某种数据本身的特征时,指定唯一索引。

  (6)在频繁排序或分组的列上创建索引,如果待排序的列有多个,可以创建组合索引。

2. 创建索引

2.1 创建表的时候创建索引

  创建表时创建索引的基本语法格式:

CREATE TABLE table_name [col_name data_type]
[UNIQUE] [INDEX | KEY] [index_name] (col_name[length]) [ASC | DESC]

  其中,INDEX与KEY为同义词,两者作用相同,用来指定创建索引。

  (1)创建普通索引

mysql> CREATE TABLE product
-> (
-> id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
-> product_no VARCHAR(255) NOT NULL DEFAULT '',
-> product_name VARCHAR(255) NOT NULL DEFAULT '',
-> KEY idx_product_no(product_no)
-> );
mysql> SHOW CREATE TABLE product;
+---------+----------------------------------------------------+
| Table | Create Table |
+---------+----------------------------------------------------+
| product | CREATE TABLE `product` (
`id` int(10) unsigned NOT NULL AUTO_INCREMENT,
`product_no` varchar(255) NOT NULL DEFAULT '',
`product_name` varchar(255) NOT NULL DEFAULT '',
PRIMARY KEY (`id`),
KEY `idx_product_no` (`product_no`)
) ENGINE=InnoDB DEFAULT CHARSET=utf8 |
+---------+----------------------------------------------------+

  (2)创建唯一索引

mysql> CREATE TABLE product
-> (
-> id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
-> product_no VARCHAR(255) NOT NULL DEFAULT '',
-> product_name VARCHAR(255) NOT NULL DEFAULT '',
-> UNIQUE KEY idx_product_no(product_no)
-> );

  (3)创建组合索引

mysql> CREATE TABLE product
-> (
-> id INT UNSIGNED AUTO_INCREMENT PRIMARY KEY,
-> product_no VARCHAR(255) NOT NULL DEFAULT '',
-> product_name VARCHAR(255) NOT NULL DEFAULT '',
-> KEY idx_product_no_name(product_no, product_name)
-> );

  组合索引遵从最左前缀:从索引最左边的列进行匹配。

2.2 查看表上的索引

  语法格式:

SHOW INDEX FROM table_name
mysql> SHOW INDEX FROM product;

  其中,主要参数:

    Table:创建索引的表

    Non_unique:索引非唯一,1表示非唯一索引,0表示唯一索引

    Key_name:索引名称

    Seq_in_index:该字段在索引中的位置,单列索引该值为1,组合索引为每个字段在索引定义中的顺序

    Column_name:定义索引的列字段

2.3 在已存在的表上创建索引

  (1)使用ALTER TABLE创建索引

ALTER TABLE table_name ADD [UNIQUE] [INDEX | KEY] [index_name] (col_name[length]) [ASC | DESC]
mysql> ALTER TABLE product ADD INDEX idx_product_no(product_no ASC);

  (2)使用CREATE INDEX创建索引

CREATE [UNIQUE] [INDEX | KEY] [index_name] ON table_name(col_name[length]) [ASC | DESC]

2.4 删除索引

  (1)使用ALTER TABLE删除索引

ALTER TABLE table_name DROP INDEX index_name;
mysql> ALTER TABLE product DROP INDEX idx_product_no;

  (2)使用DROP INDEX语句删除索引

mysql> DROP INDEX index_name on table_name;
mysql> DROP INDEX idx_product_no on product;

MySQL系列:索引基本操作(4)的更多相关文章

  1. MySQL 系列(三)你不知道的 视图、触发器、存储过程、函数、事务、索引、语句

    第一篇:MySQL 系列(一) 生产标准线上环境安装配置案例及棘手问题解决 第二篇:MySQL 系列(二) 你不知道的数据库操作 第三篇:MySQL 系列(三)你不知道的 视图.触发器.存储过程.函数 ...

  2. MySQL系列(三)---索引

    MySQL系列(三)---索引 前言:如果有疏忽或理解不当的地方,请指正. 目录 MySQL系列(一):基础知识大总结 MySQL系列(二):MySQL事务 MySQL系列(三):索引 什么是索引 如 ...

  3. MySQL系列-优化之like关键字 创建索引

    原文: https://blog.csdn.net/ufo___/article/details/81164996 MySQL系列-优化之覆盖索引:  https://blog.csdn.net/UF ...

  4. MySQL系列(九)--InnoDB索引原理

    InnoDB在MySQL5.6版本后作为默认存储引擎,也是我们大部分场景要使用的,而InnoDB索引通过B+树实现,叫做B-tree索引.我们默认创建的 索引就是B-tree索引,所以理解B-tree ...

  5. 如何选择普通索引和唯一索引《死磕MySQL系列 五》

    系列文章 一.原来一条select语句在MySQL是这样执行的<死磕MySQL系列 一> 二.一生挚友redo log.binlog<死磕MySQL系列 二> 三.MySQL强 ...

  6. 五分钟,让你明白MySQL是怎么选择索引《死磕MySQL系列 六》

    系列文章 二.一生挚友redo log.binlog<死磕MySQL系列 二> 三.MySQL强人"锁"难<死磕MySQL系列 三> 四.S 锁与 X 锁的 ...

  7. 字符串可以这样加索引,你知吗?《死磕MySQL系列 七》

    系列文章 三.MySQL强人"锁"难<死磕MySQL系列 三> 四.S 锁与 X 锁的爱恨情仇<死磕MySQL系列 四> 五.如何选择普通索引和唯一索引&l ...

  8. 为什么MySQL字符串不加引号索引失效?《死磕MySQL系列 十一》

    群里一个小伙伴在问为什么MySQL字符串不加单引号会导致索引失效,这个问题估计很多人都知道答案.没错,是因为MySQL内部进行了隐式转换. 本期文章就聊聊什么是隐式转换,为什么会发生隐式转换. 系列文 ...

  9. Mysql系列(十二)—— 索引下推优化

    索引条件下推(ICP)是对MySQL使用索引从表中检索行的情况的优化.如果没有ICP,存储引擎会遍历索引以查找基表中的行,并将它们返回给MySQL服务器,该服务器会评估WHERE行的条件.启用ICP后 ...

随机推荐

  1. P2689 东南西北

    题目描述 给出起点和终点的坐标及接下来T个时刻的风向(东南西北),每次可以选择顺风偏移1个单位或者停在原地.求到达终点的最少时间. 如果无法偏移至终点,输出“-1”. 输入输出格式 输入格式: 第一行 ...

  2. nginx.exe启动错误:bind() to 0.0.0.0:80 failed (10013: An attempt was made to access a socket in a way forbidden by its access permissions)

    启动nginx.ese之后 nginx: [emerg] bind() to 0.0.0.0:80 failed (10013: An attempt was made to access a soc ...

  3. 【CTF杂项】常见文件文件头文件尾格式总结及各类文件头

    文件头文件尾总结 JPEG (jpg), 文件头:FFD8FF 文件尾:FF D9PNG (png), 文件头:89504E47 文件尾:AE 42 60 82GIF (gif), 文件头:47494 ...

  4. 进程同步控制(锁,信号量,事件), 进程通讯(队列和管道,生产者消费者模型) 数据共享(进程池和mutiprocess.Pool模块)

    参考博客 https://www.cnblogs.com/xiao987334176/p/9025072.html#autoid-1-1-0 进程同步(multiprocess.Lock.Semaph ...

  5. # 20175329 2018-2019-2 《Java程序设计》第二周学习总结

    # 学号 2018-2019-3<Java程序设计>第三周学习总结 ## 教材学习内容总结 第二三章与我们所学习的C语言有很多的相似点,在这里我想主要就以我所学习的效果来讨论一下JAVA与 ...

  6. linux内存源码分析 - 内存压缩(实现流程)

    本文为原创,转载请注明:http://www.cnblogs.com/tolimit/ 概述 本文章最好结合linux内存管理源码分析 - 页框分配器与linux内存源码分析 -伙伴系统(初始化和申请 ...

  7. face detection[Multi-view face detection&& MTCNN]

    因为这两篇论文感觉内容较短,故而合并到一个博文中. Multi-view face detection 本文来自<Multi-view Face Detection Using Deep Con ...

  8. Clustering[Evaluation]

    0. 背景 评估(或者说验证)聚类结果就如同聚类本身一样困难.通常的方法有内部评估和外部评估这两种: 内部评估的方法:通过一个单一的量化得分来评估算法好坏:该类型的方法 外部评估的方法:通过将聚类结果 ...

  9. Python股票分析系列——基础股票数据操作(一).p3

    该系列视频已经搬运至bilibili: 点击查看 欢迎来到Python for Finance教程系列的第3部分.在本教程中,我们将使用我们的股票数据进一步分解一些基本的数据操作和可视化.我们将要使用 ...

  10. 实现一个简单的ConnectionPool

    看了一圈, 没看到稍微好用的ConnectionPool, 除了一个aiomysql, 但是这个是异步的, 我暂时没有用到这么高版本的Python, 所以就动手造一个轮子. 原理比较简单, 先造一个线 ...