索引的创建

索引的创建

创建主键索引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提供了一个内建的SQL命令帮助我们完成这个任务,这就是EXPLAIN命令。EXPLAIN命令的一般语法是:EXPLAIN 。你可以在MySQL文档找到有关该命令的更多说明。下面是一个例子:

EXPLAIN SELECT peopleid FROM people WHERE firstname=’Mike’ AND lastname=’Sullivan’ AND age=’17′;

这个命令将返回下面这种分析结果:

下面我们就来看看这个EXPLAIN分析结果的含义。

table:这是表的名字。
type:连接操作的类型。下面是MySQL文档关于ref连接类型的说明:

“对于每一种与另一个表中记录的组合,MySQL将从当前的表读取所有带有匹配索引值的记录。如果连接操作只使用键的最左前缀,或者如果键不是UNIQUE或PRIMARY KEY类型(换句话说,如果连接操作不能根据键值选择出唯一行),则MySQL使用ref连接类型。如果连接操作所用的键只匹配少量的记录,则ref是一种好的连接类型。”

在本例中,由于索引不是UNIQUE类型,ref是我们能够得到的最好连接类型。

如果EXPLAIN显示连接类型是“ALL”,而且你并不想从表里面选择出大多数记录,那么MySQL的操作效率将非常低,因为它要扫描整个表。你可以加入更多的索引来解决这个问题。预知更多信息,请参见MySQL的手册说明。

possible_keys
可能可以利用的索引的名字。这里的索引名字是创建索引时指定的索引昵称;如果索引没有昵称,则默认显示的是索引中第一个列的名字(在本例中,它是“firstname”)。默认索引名字的含义往往不是很明显。

Key
它显示了MySQL实际使用的索引的名字。如果它为空(或NULL),则MySQL不使用索引。

key_len
索引中被使用部分的长度,以字节计。在本例中,key_len是102,其中firstname占50字节,lastname占50字节,age占2字节。如果MySQL只使用索引中的firstname部分,则key_len将是50。

ref
它显示的是列的名字(或单词“const”),MySQL将根据这些列来选择行。在本例中,MySQL根据三个常量选择行。

rows
MySQL所认为的它在找到正确的结果之前必须扫描的记录数。显然,这里最理想的数字就是1。

Extra
这里可能出现许多不同的选项,其中大多数将对查询产生负面影响。在本例中,MySQL只是提醒我们它将用WHERE子句限制搜索结果集。


索引的弊端

索引并不是百利无害的,索引可以加快查询速度但是缺点也有以下两点

1)索引是十分占用磁盘空间的,如果创建很多索引很可能索引占用的磁盘空间很可能已经超过你数据所占用的磁盘空间。

2)索引的创建,在加快了查询速度的同时也使更新、插入的速度变慢。因为在更新和插入的同时,我们不仅仅要对原来的数据进行操作,同时也会更新和插入新的索引数据。所以创建合理的索引才能增强数据库的性能。

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL索引是一种数据结构,用于加快对数据的检索速度,特别是对于大型数据库。创建和查看索引是优化查询性能的关键步骤。 **创建索引:** - **基本语法:** `CREATE INDEX index_name ON table_name (column1, column2,...)` - `index_name`: 需要创建索引名称,通常简洁明了示列目的。 - `table_name`: 所在名。 - `column(s)`: 需要在这些列上建立索引的列。 - **类型选择:** MySQL支持B树、哈希等多种类型的索引,如`BTREE`, `HASH`, `FULLTEXT`等,具体根据需求选择。 - **唯一索引(UNIQUE):`CREATE UNIQUE INDEX`保证指定列组合的值唯一,不允许有重复。 - **全文索引(FULLTEXT):适合文本搜索,如`MATCH AGAINST`操作。 **查看索引:** - **查看所有索引:** 使用`SHOW INDEX FROM table_name;` - 结果会列出的所有索引以及相关信息,如索引名、非空约束、键类型等。 - **查看特定列的索引:** `SHOW INDEX FROM table_name WHERE Column_name = 'column_value';` - 查看指定列是否有索引及详细情况。 - **查看某个索引的信息:** `EXPLAIN SELECT * FROM table_name WHERE ...;` 加上`USE INDEX(index_name)`来指定使用哪个索引。 - **查看的统计信息:`ANALYZE TABLE table_name;` 可以更新MySQL的统计信息,以便更精确地选择索引。 **相关问题--:** 1. 如何在MySQL为频繁查询的列创建索引? 2. 如何判断一个是否已经存在索引? 3. 如何删除不再需要的索引
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值