你好! 这是你第一次使用 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)));