Mysql索引介绍及常见索引类别(主键索引、唯一索引、普通索引、全文索引、组合索引)的区别

时间:2022-09-22 11:16:22

MySQL索引概念:

索引就好比一本书的目录,它会让你更快的找到内容,显然目录(索引)并不是越多越好,假如这本书1000页,有500也是目录,它当然效率低,目录是要占纸张的,而索引是要占磁盘空间的。

Mysql索引方式主要有两种结构:B+树和hash.
hash:hsah索引在mysql比较少用,他以把数据的索引以hash形式组织起来,因此当查找某一条记录的时候,速度非常快.当时因为是hash结构,每个键只对应一个值,而且是散列的方式分布.所以他并不支持范围查找和排序等功能.
B+树:b+tree是mysql使用最频繁的一个索引数据结构,数据结构以平衡树的形式来组织,因为是树型结构,所以更适合用来处理排序,范围查找等功能.相对hash索引,B+树在查找单条记录的速度虽然比不上hash索引,但是因为更适合排序等操作,所以他更受用户的欢迎.毕竟不可能只对数据库进行单条记录的操作.

Mysql常见索引类别有:

主键索引、唯一索引、普通索引、全文索引、组合索引
  • PRIMARY KEY(主键索引) ALTER TABLE table_name ADD PRIMARY KEY ( column )
  • UNIQUE(唯一索引) ALTER TABLE table_name ADD UNIQUE (column)
  • INDEX(普通索引) ALTER TABLE table_name ADD INDEX index_name ( column )
  • FULLTEXT(全文索引) ALTER TABLE table_name ADD FULLTEXT ( column )
  • 组合索引 ALTER TABLE table_name ADD INDEX index_name ( column1, column2, column3 )

Mysql各种索引区别:

  • 普通索引:最基本的索引,没有任何限制
  • 唯一索引:与”普通索引”类似,不同的就是:索引列的值必须唯一,但允许有空值。
  • 主键索引:它 是一种特殊的唯一索引,不允许有空值。
  • 全文索引:仅可用于 MyISAM 表,针对较大的数据,生成全文索引很耗时好空间。
  • 组合索引:为了更多的提高mysql效率可建立组合索引,遵循”最左前缀“原则。

最左前缀:

  • alter TABLE myIndex ADD INDEX name_city_age (vc_Name(10),vc_City,i_Age);–注意了,建表时,vc_Name长度为50,这里为什么用10呢?因为一般情况下名字的长度不会超过10,这样会加速索引查询速度,还会减少索引文件的大小,提高insert的更新速度。
  • 建立这样的组合索引,其实是相当于分别建立了
    vc_Name,vc_City,i_Age
    vc_Name,vc_City
    vc_Name
  • 下面的几个T-SQL会用到:
    select * FROM myIndex WHREE vc_Name=”erquan” AND vc_City=”郑州”
    select * FROM myIndex WHREE vc_Name=”erquan”
  • 而下面几个则不会用到:
    select * FROM myIndex WHREE i_Age=20 AND vc_City=”郑州”
    select * FROM myIndex WHREE vc_City=”郑州”

在MySQL中创建表的时候,可以直接创建索引。基本的语法格式如下:

CREATE TABLE 表名(字段名 数据类型 [完整性约束条件],
[UNIQUE | FULLTEXT | SPATIAL] INDEX | KEY
[索引名](字段名1 [(长度)] [ASC | DESC])
);
UNIQUE:可选。表示索引为唯一性索引。
FULLTEXT;可选。表示索引为全文索引。
SPATIAL:可选。表示索引为空间索引。
INDEX和KEY:用于指定字段为索引,两者选择其中之一就可以了,作用是一样的。
索引名:可选。给创建的索引取一个新名称。
字段名1:指定索引对应的字段的名称,该字段必须是前面定义好的字段。
长度:可选。指索引的长度,必须是字符串类型才可以使用。
ASC:可选。表示升序排列。
DESC:可选。表示降序排列。