mysql 索引

mysql 索引

    • 目的:提高检索速度。
    • 索引分单列索引和组合索引。
    • 优缺点及适用场合
    • 索引为什么能提高查询速度
    • 普通索引
    • 唯一索引

你好! 这是你第一次使用 Markdown编辑器 所展示的欢迎页。如果你想学习如何使用Markdown编辑器, 可以仔细阅读这篇文章,了解一下Markdown的基本语法知识。

目的:提高检索速度。

索引分单列索引和组合索引。

单列索引,即一个索引只包含单个列,一个表可以有多个单列索引,但这不是组合索引。组合索引,即一个索引包含多个列。
创建索引时,确保该索引是应用在 SQL 查询语句的条件(一般作为 WHERE 子句的条件)。实际上,索引也是一张表,该表保存了主键与索引字段,并指向实体表的记录。

优缺点及适用场合

优点:提高了查询速度。
缺点:会降低更新表的速度,如对表进行INSERT、UPDATE和DELETE。因为更新表时,MySQL不仅要保存数据,还要保存一下索引文件。建立索引会占用磁盘空间的索引文件。
适用场合:大量数据,频繁查询操作,少插入更新操作,索引不宜过多。

索引为什么能提高查询速度

实现排序,利用二分法,hash等高效率的查找算法。二分法查找复杂度为O(log2n),普通为O(n)。
当一些字段频繁作为查询条件,表数据较多时,使用索引会明显提高查询速度。
全表扫描和索引扫描
读取数据时,会先在SGA的数据缓冲区读取所需要的数据,若无,则服务进程会去读磁盘。
无索引(全表扫描):直接读表存在的磁盘块,读到数据缓冲区后再去查找所需要的数据。
有索引:先读索引表,根据索引表直接找到所需的物理块地址,并把数据读到数据缓冲区。

普通索引

创建索引

CREATE INDEX indexName ON mytable(username(length));
如果是CHAR,VARCHAR类型,length可以小于字段实际长度;如果是BLOB和TEXT类型,必须指定 length。

修改表结构(添加索引)

ALTER table tableName ADD INDEX indexName(columnName)

创建表时指定

CREATE TABLE mytable(
ID INT NOT NULL,
username VARCHAR(16) NOT NULL,
INDEX [indexName] (username(length)));

删除索引

DROP INDEX [indexName] ON mytable;

显示索引信息

SHOW INDEX FROM table_name;

唯一索引

索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。

创建索引

CREATE UNIQUE INDEX indexName ON mytable(username(length))

修改表结构

ALTER table mytable ADD UNIQUE [indexName] (username(length))

创建表的时候直接指定

CREATE TABLE mytable(
ID INT NOT NULL,
username VARCHAR(16) NOT NULL,
UNIQUE [indexName] (username(length)));

你可能感兴趣的:(mysql)