MySQL之索引创建、删除、唯一索引、普通索引、及命名规则、注意事项
一、MySQL 索引 定义
索引是一个数据结构,用于加速数据库表中数据的查询。索引存储了一些数据表中的列值,以及这些列值在数据表中的位置,这样就可以通过索引来快速查找到数据表中的某一行数据。
MySQL 支持多种索引类型,包括普通索引
、唯一索引
、主键索引
和全文索引
等。
使用索引可以大大加快查询速度,但同时也带来了一些开销,因为维护索引需要额外的存储空间和时间
二、索引语句
-
查看某张表索引
show index from account;
-
删除某个索引
drop index idx_name on talbe_name; alter table table_name drop index idx_name;
-
创建普通索引
create index idx_name on table_name (column_1, column_2, ...); create index idx_email on account (email);alter table table_name add index index_name (column_1, column_2, ...) alter table account add index idx_email (email);
-
创建普通索引
create unique index uniq_name on table_name (column_1, column_2, ...); create unique index uniq_email on account (email);alter table table_name add unique uniq_name (column_1, column_2, ...); alter table account add unique uniq_email (email);
-
创建全文索引(是一种特殊类型的索引,用于对文本数据进行全文搜索。它可以对文本数据进行分词,并为每个分词建立索引,以支持快速检索数据)
alter table table_name add fulltext index idx_name (column_1, column_2, ...);
创建索引注意事项
- 索引列应该是经常被查询和排序的列。
- 尽量选择具有唯一值的列作为索引列,因为这样可以提高索引的效率。
- 索引列的数据类型应该尽量简单,例如整数或字符串,而不是复杂的数据类型,如日期和时间。
- 如果索引列的长度较长,应该选择前面的一部分作为索引。
- 不要对大量重复的列创建索引,因为这样可能会导致索引变得很大,并降低性能。
- 避免创建太多的索引:如果表中有太多的索引,那么插入、更新和删除操作可能会变慢。
- 尽量避免对于 NULL 值的列创建索引:如果列中有大量的 NULL 值,那么索引可能会变得非常大,从而降低查询性能。
- 避免在多个列上创建组合索引,除非它们经常被查询和排序。
- 需要注意的是,创建索引可以提高查询性能,但是也会增加表的大小,因此应根据需要选择是否创建索引。