您现在的位置是:网站首页 > 博客日记 >

mysql索引

作者:YXN-sql 阅读量:47 发布日期:2024-05-22

索引的分类

在SQL中,索引是一种数据结构,它可以帮助数据库高效地查询、更新数据表中的数据。

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

从功能逻辑上说,索引主要有4类:

  • 普通索引
  • 唯一索引:唯一索引不允许两个行有相同的索引值。
  • 主键索引:一种特殊的唯一索引,用于唯一标识表中的每一条记录。
  • 全文索引:用于MyISAM引擎,可以用于InnoDB(从MySQL 5.6开始支持),可以在CHAR、VARCHAR或者TEXT类型的列上创建。

按照作用字段个数进行划分,分成:

  • 单列索引:在单个列上创建的索引。
  • 联合索引:在多个列上创建的索引,可以用于联合查询优化。

按照物理实现方式,索引可以分为2种:

  • 聚簇索引
  • 非聚簇(cu)索引

1、普通索引

在创建普通索引时,不附加任何限制条件,只是用于提高查询效率。这类索引可以创建在任何数据类型中,其值是否唯一和非空,要由字段本身的完整性约束条件决定。建立索引以后,可以通过索引进行查询。例如,在表 student 的字段 name 上建立一个普通索引,查询记录时就可以根据该索引进行查询。

2、唯一索引 

使用 UNIQUE 参数可以设置索引为唯一性索引,在创建唯一性索引时,限制该索引的值必须是唯一的,但允许有空值。在一张数据表里可以有多个唯一索引。

例如,在表 student 的字段 email 中创建唯一性索引,那么字段 email 的值就必须是唯一的。通过唯一性索引,可以更快速地确定某条记录

3、 主键索引

主键索引就是一种特殊的唯一性索引,在唯一索引的基础上增加了不为空的约束,也就是 NOT NULL + UNIQUE,一张表里最多只有一个主键索引

4、全文索引 

全文索引(也称全文检索)是目前搜索引擎使用的一种关键技术。它能够利用【分词技术】等多种算法智能分析出文本文字中关键词的频率和重要性,然后按照一定的算法规则智能地筛选出我们想要的搜索结果。全文索引非常适合大型数据集,对于小的数据集,它的用处比较小。

使用参数 FULLTEXT 可以设置索引为全文索引。在定义索引的列上支持值的全文查找,允许在这些索引列中插入重复值和空值。全文索引只能创建在 CHAR、VARCHAR 或 TEXT 类型及其系列类型的字段上,查询数据量较大的字符串类型的字段时,使用全文索引可以提高查询速度。例如,表 student 的字段 infomation 是 TEXT 类型,该字段包含了很多文字信息。在字段 information 上建立全文索引后,可以提高查询字段 information 的速度

5、单列索引

在表的单个字段上创建索引。单列索引只根据该字段进行索引。单列索引可以是普通索引,也可以是唯一性索引,还可以是全文索引。只要保证该索引只对应一个字段即可。一个表可以有多个单列索引。 

6、多列(组合、联合)索引

多列索引是在表的多个字段组合上创建一个索引。该索引指向创建时对应的多个字段,可以通过这几个字段进行查询,但是只有查询条件中使用了这些字段的第一个字段时才会被使用。例如,在表的字段 id、name 和 gender 上建立一个多列索引 idx_id_name_gender ,只有在查询条件中使用了字段 id 时该索引才会被使用。使用组合索引时遵循最左前缀集合

创建索引语句

-- 创建一个普通索引
CREATE INDEX index_name ON table_name(column_name);
 
-- 创建一个唯一索引
CREATE UNIQUE INDEX index_name ON table_name(column_name);
 
-- 创建一个全文索引
CREATE FULLTEXT INDEX index_name ON table_name(column_name);
 
-- 创建一个空间索引
CREATE SPATIAL INDEX index_name ON table_name(column_name);
 
-- 创建一个组合索引
CREATE INDEX index_name ON table_name(column1, column2, ...);

YXN-sql

2024-05-22