mysql 索引

mysql实战后,接下来学习重头戏,索引!

索引用于快速找出在某个列中有一特定值的行。不使用索引,MySQL必须从第1条记录开始读完整个表,直到找出相关的行。表越大,查询数据所花费的时间越多。如果表中查询的列有一个索引,MySQL 能快速到达某个位置去搜寻数据文件,而不必查看所有数据。将介绍与索引相关的内容,包括索引的含义和特点、索引的分类、索引的设计原则以及如何创建和删除索引。

1,索引介绍

索引是对数据库表中一列或多列的值进行排序的一种结构,使用索引可提高数据库中特定数据的查询速度。本节将介绍索引的含义、分类和设计原则。

1,索引的含义和特点

索引是一个单独的、存储在磁盘上的数据库结构,它们包含着对数据表里所有记录的引用指针。使用索引用于快速找出在某个或多个列中有一特定值的行,所有MySQL列类型都可以被索引,对相关列使用索引是提高查询操作速度的最佳途径。

例如:数据库中有2万条记录,现在要执行这样一个查询:

sql 复制代码
SELECT * FROM table where num=10000;

如果没有索引,必须遍历整个表,直到 num 等于10000的这一行被找到为止;如果在num列上创建索引,MySQL不需要任何扫描,直接在索引里面找10000,就可以得知这一行的位置。可见,索引的建立可以提高数据库的查询速度。

索引是在存储引擎中实现的,因此,每种存储引擎的索引都不一定完全相同,并且每种存储引擎也不一定支持所有索引类型。根据存储引擎定义每个表的最大索引数和最大索引长度。所有存储引擎支持每个表至少16个索引,总索引长度至少为256字节。大多数存储引擎有更高的限制。

MySQL 中索引的存储类型有两种:BTREE 和HASH,具体和表的存储引擎相关;MyISAM 和 InnoDB存储引擎只支持BTREE索引; MEMORY/HEAP存储引擎可以支持HASH和BTREE索引。

索引的优点主要有以下几条:

(1)通过创建唯一索引,可以保证数据库表中每一行数据的唯一性。

(2)可以大大加快数据的查询速度,这也是创建索引的最主要的原因。

(3)在实现数据的参考完整性方面,可以加速表和表之间的连接。

(4)在使用分组和排序子句进行数据查询时,也可以显著减少查询中分组和排序的时间。

增加索引也有许多不利,主要表现在如下几个方面:

(1)创建索引和维护索引要耗费时间,并且随着数据量的增加所耗费的时间也会增加。

(2)索引需要占磁盘空间,除了数据表占数据空间之外,每一个索引还要占一定的物理空间,如果有大量的索引,索引文件可能比数据文件更快达到最大文件尺寸。

(3)当对表中的数据进行增加、删除和修改的时候,索引也要动态地维护,这样就降低了数据的维护速度。

2,索引的分类

MySQL的索引可以分为以下几类:

普通索引和唯一索引

普通索引是MySQL中的基本索引类型,允许在定义索引的列中插入重复值和空值。唯一索引,索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一。主键索引是一种特殊的唯一索引,不允许有空值。

单列索引和组合索引

单列索引即一个索引只包含单个列,一个表可以有多个单列索引。

组合索引指在表的多个字段组合上创建的索引,只有在查询条件中使用了这些字段的左边字段时,索引才会被使用。使用组合索引时遵循最左前缀集合。

全文索引

全文索引类型为 FULLTEXT,在定义索引的列上支持值的全文查找,允许在这些索引列中插入重复值和空值。全文索引可以在CHAR、VARCHAR 或者TEXT类型的列上创建。MySQL中只有MyISAM存储引擎支持全文索引

空间索引

空间索引是对空间数据类型的字段建立的索引,MySQL 中的空间数据类型有4种,分别是:GEOMETRY、POINT、LINESTRING和 POLYGON。MySQL使用SPATIAL关键字进行扩展,使得能够用于创建正规索引类似的语法创建空间索引。创建空间索引的列,必须将其声明为NOT NULL,空间索引只能在存储引擎为MyISAM的表中创建。

3,索引的设计原则

索引设计不合理或者缺少索引都会对数据库和应用程序的性能造成障碍。高效的索引对·于获得良好的性能非常重要。设计索引时,应该考虑以下准则:

(1)索引并非越多越好,一个表中如有大量的索引,不仅占用磁盘空间,而且会影响INSERT、DELETE、UPDATE等语句的性能,因为当表中的数据更改的同时,索引也会进行调整和更新。

(2)避免对经常更新的表进行过多的索引,并且索引中的列尽可能少。而对经常用于查询的字段应该创建索引,但要避免添加不必要的字段。

(3)数据量小的表最好不要使用索引,由于数据较少,查询花费的时间可能比遍历索引的时间还要短,索引可能不会产生优化效果。

(4)在条件表达式中经常用到的不同值较多的列上建立索引,在不同值很少的列上不要建立索引。比如在学生表的"性别"字段上只有"男"与"女"两个不同值,因此就无须建立索引。如果建立索引不但不会提高查询效率,反而会严重降低数据更新速度。

(5)当唯一性是某种数据本身的特征时,指定唯一索引。使用唯一索引需能确保定义的列的数据完整性,以提高查询速度。

(6)在频繁进行排序或分组(即进行group by或order by操作)的列上建立索引,如果待排序的列有多个,可以在这些列上建立组合索引。

2,创建索引

MySQL支持多种方法在单个或多个列上创建索引:在创建表的定义语句CREATE TABLE中指定索引列,使用ALTER TABLE 语句在存在的表上创建索引,或者使用CREATE INDEX

语句在已存在的表上添加索引。

1,创建表的时候创建索引

使用CREATE TABLE创建表时,除了可以定义列的数据类型,还可以定义主键约束、外键约束或者唯一性约束,而不论创建那种约束,在定义约束的同时相当于在指定列上创建了一个索引。创建表时创建索引的基本语法格式如下:

sql 复制代码
CREATE TABLE table_name [col_name data_type]
[UNIQUE | FULLTEXT | SPATIAL] [INDEX | KEY] 
[index_name] (col_name [length]) [ASC | DESC]

UNIQUE、FULLTEXT和SPATIAL为可选参数,分别表示唯一索引、全文索引和空间索引;INDEX与 KEY为同义词,两者作用相同,用来指定创建索引;col_name为需要创建索引的字段列,该列必须从数据表中定义的多个列中选择; index_name指定索引的名称,为可选参数,如果不指定,MySQL默认 col_name为索引值;length为可选参数,表示索引的长度,只有字符串类型的字段才能指定索引长度;ASC或 DESC指定升序或者降序的索引值存储。

1,创建普通索引

最基本的索引类型,没有唯一性之类的限制,其作用只是加快对数据的访问速度。

【例1】在 book表中的year_publication字段上建立普通索引,SQL语句如下:

sql 复制代码
CREATE TABLE book(
  book_id INT NOT NULL,
  book_name VARCHAR(255) NOT NULL,
  authors VARCHAR(255) NOT NULL,
  info VARCHAR(255) NULL,
  comment VARCHAR(255) NULL,
  year_publication YEAR NOT NULL,
  INDEX (year_publication)
);

该语句执行完毕之后,使用SHoW CREATE TABLE查看表结构:

sql 复制代码
SHOW CREATE table book;

由结果可以看到,book表的year_publication字段上成功建立索引,其索引名称year_publication为 MySQL自动添加。使用EXPLAIN语句查看索引是否正在使用:

sql 复制代码
 explain select * from book where year_publication = 1990;

EXPLAIN语句输出结果的各个行解释如下:

(1) select_type行指定所使用的SELECT查询类型,这里值为SIMPLE,表示简单的SELECT,不使用UNION或子查询。其他可能的取值有:PRIMARY、UNION、SUBQUERY等。

(2)table行指定数据库读取的数据表的名字,它们按被读取的先后顺序排列。

(3) type行指定了本数据表与其他数据表之间的关联关系,可能的取值有system、const、eq_ref、ref、range、index 和 All。

(4) possible_keys行给出了MySQL在搜索数据记录时可选用的各个索引。

(5) key行是MySQL实际选用的索引。

(6) key_len 行给出索引按字节计算的长度,key_len数值越小,表示越快

(7) ref行给出了关联关系中另一个数据表里的数据列的名字。

( 8) rows行是MySQL在执行这个查询时预计会从这个数据表里读出的数据行的个数。

( 9) extra行提供了与关联操作有关的信息。

可以看到,possible_keys和 key的值都为year_publication,查询时使用了索引。

2,创建唯─索引

创建唯一索引的主要原因是减少查询索引列操作的执行时间,尤其是对比较庞大的数据表。它与前面的普通索引类似,不同的就是:索引列的值必须唯一,但允许有空值。如果是组合索引,则列值的组合必须唯一

【例2】创建一个表t1,在表中的id字段上使用UNIQUE关键字创建唯一索引。

sql 复制代码
CREATE TABLE t1 (
 id INT NOT NULL,
 name CHAR(30) NOT NULL,
 UNIQUE INDEX UniqIdx (id)
 );

该语句执行完毕之后,使用SHOW CREATE TABLE查看表结构:

sql 复制代码
SHOW CREATE table t1;

由结果可以看到,id字段上已经成功建立了一个名为UniqIdx 的唯一索引。

3,创建单列索引

单列索引是在数据表中的某一个字段上创建的索引,一个表中可以创建多个单列索引。前面两个例子中创建的索引都为单列索引。

【例3】创建一个表t2,在表中的name字段上创建单列索引。表结构如下:

sql 复制代码
CREATE TABLE t2 (
 id INT NOT NULL,
 name CHAR(50) NOT NULL,
 INDEX SingleIdx (name(20))
 );

该语句执行完毕之后,使用SHOW CREATE TABLE查看表结构:

sql 复制代码
SHOW CREATE table t2; 

由结果可以看到,id字段上已经成功建立了一个名为Singleldx的单列索引,索引长度为20。

4,创建组合索引

组合索引是在多个字段上创建一个索引。

【例4】创建表t3,在表中的id、name和 age字段上建立组合索引,SQL语句如下:

sql 复制代码
CREATE TABLE t3
(
  id INT NOT NULL,
  name CHAR(30) NOT NULL,
  age INT NOT NULL,
  info VARCHAR(255),
  INDEX MultiIdx(id, name, age(100))
);

错误代码: 1089

Incorrect prefix key; the used key part isn't a string, the used length is longer than the key part, or the storage engine doesn't support unique prefix keys

报错的原因之一:

定义的前缀索引长度超过字段本身的长度。例如,定义字段column_a的长度为128字符,即column_a varchar(128),设置前缀索引时的长度为130字符,即key idx_a(column_a(130)),则报错产生。需要确保前缀索引的长度小于字段本身的长度。

先把长度先去了:

sql 复制代码
CREATE TABLE t3
(
  id INT NOT NULL,
  name CHAR(30) NOT NULL,
  age INT NOT NULL,
  info VARCHAR(255),
  INDEX MultiIdx (id, name, age)
);

该语句执行完毕之后,使用SHOW CREATE TABLE查看表结构:

sql 复制代码
SHOW CREATE table t3;

由结果可以看到,id、name和 age字段上已经成功建立了一个名为Multildx 的组合索引。组合索引可起几个索引的作用,但是使用时并不是随便查询哪个字段都可以使用索引,而是遵从"最左前缀";利用索引中最左边的列集来匹配行,这样的列集称为最左前缀。例如这里由id、name和 age 3个字段构成的索引,索引行中按id/name/age的顺序存放,索引可以搜索下面字段组合:(id, name, age) 、 (id, name)或者id。如果列不构成索引最左面的前缀,MySQL不能使用局部索引,如(age)或者(name,age)组合则不能使用索引查询。

在t3表中,查询id和 name字段,使用EXPLAIN语句查看索引的使用情况:

sql 复制代码
explain select* from t3 where id=1 AND name='joe';

可以看到,查询 id和name字段时,使用了名称Multildx的索引,如果查询(name,age)组合或者单独查询name和 age字段,结果如下:

此时,possible_keys和 key值为NULL,并没有使用在t3表中创建的索引进行查询。

PS:最左前缀原则,例如这里由id、name和 age 3个字段构成的索引, 跟id的位置没有关系,跟是否存在有关系, (name, age,id ) 、 (name, id)都是满足的。

5,创建全文索引

FULLTEXT(全文索引)可以用于全文搜索。只有MyISAM 存储引擎支持FULLTEXT索引,并且只为CHAR、VARCHAR和TEXT列创建索引。索引总是对整个列进行,不支持局部(前缀)索引。

【例5】创建表t4,在表中的 info字段上建立全文索引,SQL语句如下:

sql 复制代码
CREATE TABLE t4(
    id INT NOT NULL,
    name CHAR(30) NOT NULL,
    age INT NOT NULL,
    info VARCHAR(255),
    FULLTEXT INDEX FullTxtIdx (info)
) ENGINE=MyISAM;

提示:因为MySQL 5.7中默认存储引擎为InnoDB,在这里创建表时需要修改表的存储引擎为MyISAM,不然创建索引会出错。

语句执行完毕之后,使用SHOW CREATE TABLE查看表结构:

sql 复制代码
SHOW CREATE table t4; 

由结果可以看到,info字段上已经成功建立了一个名为FullTxtIdx的 FULLTEXT索引。全文索引非常适合于大型数据集,对于小的数据集,它的用处比较小。

6,创建空间索引

空间索引必须在MyISAM类型的表中创建,且空间类型的字段必须为非空。

【例6】创建表t5,在空间类型为GEOMETRY的字段上创建空间索引,SQL语句如下:

sql 复制代码
CREATE TABLE t5
(
  g GEOMETRY NOT NULL, 
  SPATIAL INDEX spatIdx(g)
)ENGINE=MyISAM;

该语句执行完毕之后,使用SHOW CREATE TABLE查看表结构:

sql 复制代码
SHOW CREATE table t5;

可以看到,t5表的g字段上创建了名称为spat1dx的空间索引。注意创建时指定空间类型字段值的非空约束,并且表的存储引擎为MyISAM。

2,在已经存在的表上创建索引

在已经存在的表中创建索引,可以使用ALTER TABLE语句或者CREATE INDEX语句。如何使用ALTER TABLE 和 CREATE INDEX语句在已知表字段上创建索引。

1,使用ALTER TABLE语句创建索引

ALTER TABLE创建索引的基本语法如下:

sql 复制代码
ALTER TABLE table_name ADD [UNIQUE| FULLTEXT | SPATIAL]  [INDEX | KEY][index_name] (col_name[length],....) [ASC I DESC]

与创建表时创建索引的语法不同的是,在这里使用了ALTER TABLE和ADD关键字,ADD表示向表中添加索引。

【例7】在book表中的bookname字段上建立名为BkNameldx的普通索引。添加索引之前,使用SHOW INDEX语句查看指定表中创建的索引:

sql 复制代码
SHOW INDEX FROM book;

其中各个主要参数的含义为:

(1) Table表示创建索引的表。

(2) Non_unique表示索引非唯一,1代表是非唯一索引,0代表唯一索引。

(3) Key_name表示索引的名称。

(4) Seq_in_index表示该字段在索引中的位置,单列索引该值为1,组合索引为每个字段在索引定义中的顺序。

(5) Column_name表示定义索引的列字段。

(6) Sub_part表示索引的长度。

(7) Null表示该字段是否能为空值

(8) Index_type表示索引类型。

可以看到,book 表中已经存在了一个索引,即前面已经定义的名称为year_publication索引,该索引为非唯一索引。

下面使用ALTER TABLE在bookname字段上添加索引,SQL语句如下:

sql 复制代码
ALTER TABLE book ADD INDEX BkNameIdx( bookname (30));

使用SHOW INDEX语句查看表中的索引:

sql 复制代码
SHOW INDEX FROM book;

可以看到,现在表中已经有了两个索引,另一个为通过ALTER TABLE语句添加的名称为 BkNameldx的索引,该索引为非唯一索引,长度为30。

【例8】在 book表的 bookld字段上建立名称为Uniqidldx 的唯一索引,SQL语句如下:

sql 复制代码
ALTER TABLE book ADD UNIQUE INDEX UniqidIdx(book_id);

使用SHOW INDEX语句查看表中的索引:

sql 复制代码
SHOW INDEX FROM book;

可以看到Non_unique属性值为0,表示名称为UniqidIdx的索引为唯一索引,创建唯一索引成功。

【例9】在 book表的comment字段上建立单列索引,SQL语句如下:

sql 复制代码
ALTER TABLE book ADD INDEX BkcmtIdx(COMMENT(50));

使用SHOW INDEX语句查看表中的索引:

sql 复制代码
SHOW INDEX FROM book;

可以看到,语句执行之后在book 表的comment字段上建立了名称为BkcmgIdx的索引,长度为50,在查询时,只需要检索前50个字符。

【例10】在book表的authors和 info字段上建立组合索引,SQL语句如下:

sql 复制代码
ALTER TABLE book ADD INDEX BkAuAndInfoldx (authors(30), info(50));

使用SHOW INDEX语句查看表中的索引:

sql 复制代码
SHOW INDEX FROM book;

可以看到名称为 BkAuAndInfoldx 的索引由两个字段组成,authors字段长度为30,在组合索引中的序号为1,该字段不允许空值NULL; info字段长度为50,在组合索引中的序号为2,该字段可以为空值NULL。

【例11】创建表t6,在t6表上使用ALTER TABLE创建全文索引。首先创建表t6,语句如下:

sql 复制代码
CREATE TABLE t6(
  id INT NOT NULL,
  info CHAR(255)
)ENGINE=MyISAM;

注意修改ENGINE参数为MyISAM,MySQL默认引擎InnoDB不支持全文索引。使用ALTER TABLE语句在 info字段上创建全文索引:

sql 复制代码
ALTER TABLE t6 ADD FULLTEXT INDEX infoFTIdx(info);

使用SHOW INDEX语句查看索引:

sql 复制代码
SHOW index from t6;

可以看到,t6表中已经创建了名称为infoFTIdx的索引,该索引在 info字段上创建,类型为FULLTEXT,允许空值。

【例12】创建表t7,在t7的空间数据类型字段g上创建名称为spatIdx 的空间索引,SQL语句如下:

sql 复制代码
CREATE TABLE t7(g GEOMETRY NOT NULL )ENGINE=MyISAM;

使用ALTER TABLE在表t7的g字段建立空间索引:

sql 复制代码
ALTER TABLE t7 ADD SPATIAL INDEX spatIdx(g);

使用SHOW INDEX语句查看索引:

sql 复制代码
SHOW index from t7;

可以看到t7表的g字段上创建了名称为spat1dx的空间索引。

2,使用CREATE INDEX创建索引

CREATE INDEX语句可以在已经存在的表上添加索引,MySQL 中 CREATE INDEX被映射到一个ALTER TABLE语句上,基本语法结构为:

sql 复制代码
CREATE [UNIQUE | FULLTEXT | SPATIAL] INDEX index_name ON table_name (col_nane[length],...) [ASC | DESC]

可以看到CREATE INDEX语句和ALTER TABLE语句的语法基本一样只是关键字不同在这里,使用相同的表book,假设该表中没有任何索引值,创建book表语句如下:

sql 复制代码
DROP TABLE IF EXISTS book;
CREATE TABLE book (
  book_id INT NOT NULL,
  book_name VARCHAR(255) NOT NULL,
  AUTHORS VARCHAR(255)NOT NULL,
  info VARCHAR(255) NULL,
  COMMENT VARCHAR(255) NULL,
  year_publication YEAR NOT NULL
);

【例13】在 book表中的 bookname字段上建立名为BkNameldx 的普通索引,SQL语句如下:

sql 复制代码
CREATE INDEX BkNameIdx ON book (bookname);

语句执行完毕之后,将在 book表中创建名称为 BkNameldx的普通索引。可以使用SHOW INDEX或者SHOW CREATE TABLE语句查看book表中的索引,其索引内容与前面介绍相同。

【例14】在 book表的 bookld字段上建立名称为UniqidIdx的唯一索引,SQL语句如下:

sql 复制代码
CREATE UNIQUE INDEX UniqidIdx ON book ( bookId );

语句执行完毕之后,将在book表中创建名称为UniqidIdx的唯一索引。

【例15】在book表的comment字段上建立单列索引,SQL语句如下:

sql 复制代码
CREATE INDEX BkcmtIdx ON book(comment (50));

语句执行完毕之后,将在 book表的comment 字段上建立一个名为Bkcmt1dx的单列索引,长度为50。

【例16】在 book表的authors和 info字段上建立组合索引,SQL语句如下:

sql 复制代码
CREATE INDEX BkAuAndInfoIdx ON book ( authors (20),info(50));

语句执行完毕之后将在book表的authors和 info字段上建立了一个名为BkAuAndInfoldx的组合索引,authors 的索引序号为1,长度为20,info的索引序号为2,长度为50。

【例17】删除表t6,重新建立表t6,在t6表中使用CREATE INDEX语句,在CHAR类型的info字段上创建全文索引,SQL语句如下:

首先删除表t6,并重新建立该表,分别输入下面语句:

sql 复制代码
DROP TABLE IF EXISTS t6;

CREATE TABLE t6
(
  id INT NOT NULL,
  info CHAR(255)
)ENGINE=MyISAM;

使用CREATE INDEX 在t6表的 info字段上创建名称为infoFTIdx的全文索引:

sql 复制代码
CREATE PULLTEXT INDEX ON t6(info);

语句执行完毕之后将在t6表中创建名称为infoFTIdx的索引该索引在info字段上创建类型为FULLTEXT,允许空值。

【例18】删除表t7,重新创建表t7,在t7表中使用CREATE INDEX语句,在空间数据类型字段g上创建名称为spat1dx的空间索引,SQL语句如下:

首先删除表t7,并重新建立该表,分别输入下面语句:

sql 复制代码
DROP TABLE IF EXISTS t7;

CREATE TABLE t7 (g GEOMETRY NOT NULL) ENGINE=MyISAM;

使用CREATE INDEX语句在表t7的g字段建立空间索引,

sql 复制代码
CREATE SPATIAL INDEX spatIdx ON t7(g);

语句执行完毕之后,将在t7表中创建名称为spat1dx的空间索引该索引在g字段上创建。

3,删除索引

MySQL 中删除索引使用ALTER TABLE或者DROP INDEX语句,两者可实现相同的功能,DROP INDEX语句在内部被映射到一个ALTER TABLE语句中。

1,使用ALTER TABLE删除索引

ALTER TABLE删除索引的基本语法格式如下:

sql 复制代码
ALTER TABLE table_name DROP INDEX index_name;

【例19】删除book表中名称为Uniqidldx的唯一索引。

首先查看book表中是否有名称为UniqidIdx的索引,输入SHOW语句如下:

sql 复制代码
SHOW CREATE table book;

查询结果可以看到,book表中有名称为Uniqidldx 的唯一索引,该索引在 bookid 字段上创建,下面删除该索引,输入删除语句如下:

sql 复制代码
ALTER TABLE book DROP INDEX UniqidIdx;

语句执行完毕,使用SHOW语句查看索引是否被删除:

sql 复制代码
SHOW CREATE table book;

由结果可以看到,book表中已经没有名称为UniqidIdx 的唯一索引,删除索引成功。

添加AUTO_INCREMENT 约束字段的唯一索引不能被删除。

2,使用DROP INDEX语句删除索引

DROP INDEX删除索引的基本语法格式如下:

sql 复制代码
DROP INDEX index_name ON table_name;

【例20】删除 book表中名称为BkAuAndInfoldx的组合索引,SQL语句如下:

sql 复制代码
DROP INDEX BkAuAndInfoIdx ON book;

语句执行完毕,使用SHOW语句查看索引是否被删除:

sql 复制代码
SHOW CREATE table book;

可以看到,book表中已经没有名称为BkAuAndInfoldx的组合索引,删除索引成功。

提示:删除表中的列时,如果要删除的列为索引的组成部分,则该列也会从索引中删除。如果组成索引的所有列都被删除,则整个索引将被删除。

4,疑问解答

疑问1:索引对数据库性能如此重要,应该如何使用它?

为数据库选择正确的索引是一项复杂的任务。如果索引列较少,则需要的磁盘空间和维护开销都较少。如果在一个大表上创建了多种组合索引,索引文件也会膨胀很快。而另一方面,索引较多可覆盖更多的查询。可能需要试验若干不同的设计,才能找到最有效的索引。可以添加、修改和删除索引而不影响数据库架构或应用程序设计。因此,应尝试多个不同的索引从而建立最优的索引。

疑问2∶尽量使用短索引。

对字符串类型的字段进行索引,如果可能应该指定一个前缀长度。例如,如果有一个CHAR(255)的列,如果在前10个或30个字符内,多数值是唯一的,则不需要对整个列进行索引。短索引不仅可以提高查询速度而且可以节省磁盘空间、减少IO操作。

总结:

设计索引的时候,要谨记索引的原则:

(1)索引并非越多越好,一个表中如有大量的索引,不仅占用磁盘空间,而且会影响INSERT、DELETE、UPDATE等语句的性能,因为当表中的数据更改的同时,索引也会进行调整和更新。

(2)避免对经常更新的表进行过多的索引,并且索引中的列尽可能少。而对经常用于查询的字段应该创建索引,但要避免添加不必要的字段。

(3)数据量小的表最好不要使用索引,由于数据较少,查询花费的时间可能比遍历索引的时间还要短,索引可能不会产生优化效果。

(4)在条件表达式中经常用到的不同值较多的列上建立索引,在不同值很少的列上不要建立索引。比如在学生表的"性别"字段上只有"男"与"女"两个不同值,因此就无须建立索引。如果建立索引不但不会提高查询效率,反而会严重降低数据更新速度。

(5)当唯一性是某种数据本身的特征时,指定唯一索引。使用唯一索引需能确保定义的列的数据完整性,以提高查询速度。

(6)在频繁进行排序或分组(即进行group by或order by操作)的列上建立索引,如果待排序的列有多个,可以在这些列上建立组合索引。

把基础学完,再继续学习索引的优化。

上一篇: 《mysql 重复单号 统计

下一篇: 《mysql 存储过程和函数

相关推荐
却道天凉_好个秋2 天前
MySQL高级(四):索引
数据库·mysql·索引
一叶飘零_sweeeet14 天前
MySQL 索引
数据库·mysql·索引
来一杯龙舌兰17 天前
【MongoDB】MongoDB的聚合(Aggregate、Map Reduce)与管道(Pipline) 及索引详解(附详细案例)
数据库·mongodb·mapreduce·索引·aggregate·pipline
yunteng52119 天前
mysql(一)
b+tree·msyql·分表分库·smo·单表最大行数
凌波漫步&2 个月前
数据库索引和磁盘的关系大揭秘
数据库·磁盘·索引
极客先躯2 个月前
高级java每日一道面试题-2024年9月29日-数据库篇-索引怎么定义,分哪几种?
java·数据结构·数据库·分类·索引·全文索引·聚集索引
代码代码快快显灵2 个月前
Mysql之索引优化
数据库·mysql·索引·索引优化
醉颜凉2 个月前
什么是聚集索引?
数据库·mysql·面试·索引·数据库性能·聚集索引
cyt涛2 个月前
搜索功能技术方案
mysql·elasticsearch·全文检索·canal·索引·数据同步·搜索
jamesdodo2 个月前
SQL创建索引加快查询速度的方法
数据库·sql·索引·加快sql查询