当前位置: 移动技术网 > IT编程>数据库>Mysql > 浅析mysql索引

浅析mysql索引

2017年12月07日  | 移动技术网IT编程  | 我要评论

刘刘的一亩三分地,百阅街,孙更俊

数据库索引是一种数据结构,目的是提高表的操作速度。可以使用一个或多个列,提供快速随机查找和访问记录的高效排序来创建索引。

要创建的索引,应当认为哪列将用于使sql查询,创建对这些列的一个或多个索引。

实际上,索引也是表,其中保存主键或索引字段的指针并指向每个记录到实际的表的类型。

用户无法看到索引,它们只是用来加速查询,并将被用于数据库搜索引擎在查找记录时提高速度。

insert和update语句需要更多的时间来创建索引,作为在select语句快速在这些表上操作。其原因是,在执行插入或更新数据时,数据库需要将插入或更新索引值也更新。

简单和唯一索引

可以在表上创建唯一值索引。唯一索引意味着两行不能有相同的索引值。下面是在表上创建索引的语法:

create unique index index_name
on table_name ( column1, column2,...);

可以使用一个或多个列来创建索引。例如,我们可以使用tutorial_author 来创建一个 tutorials_tbl 索引。

create unique index author_index
on tutorials_tbl (tutorial_author)

可以在表上创建一个简单的索引。创建简单的索引只是省略unique关键字。简单的索引可以在表中重复的值。

如果想索引的列的值按降序排列,可以列名之后添加保留字desc。

mysql> create unique index author_index
on tutorials_tbl (tutorial_author desc)

使用alter命令来添加和删除索引

有四种类型的索引可以添加到一个表:

  • alter table tbl_name add primary key (column_list):  添加一个主键(primary key),这意味着索引值必须是唯一的,而不能为空。
  • alter table tbl_name add unique index_name (column_list):  创建一个索引的量的值必须是唯一的(除了不能使用null值,其它的可以出现多次)。
  • alter table tbl_name add index index_name (column_list):  增加普通的索引,其中的任何值的出现多次。
  • alter table tbl_name add fulltext index_name (column_list): 创建一个用于文本搜索目的一种特殊的fulltext索引。

下面是一个添加索引到现有表的例子。

mysql> alter table testalter_tbl add index (c);

可以通过使用 alter 命令以及drop子句来删除索引。试试下面的例子,用来删除上面创建的索引。

mysql> alter table testalter_tbl drop index (c);

使用alter命令来添加和删除primary key

也可以用同样的方法添加主键。但要在列确保主键正常使用,需要指定使用 not null。

下面是一个例子添加主键在现有的表。列需要添加 not null 属性,然后再添加为一个主键。

mysql> alter table testalter_tbl modify i int not null;
mysql> alter table testalter_tbl add primary key (i);

可以使用alter命令删除主键如下:

mysql> alter table testalter_tbl drop primary key;

要删除索引的不是主键,必须指定索引名。

显示索引信息

可以使用show index命令,列出所有与表相关的索引。 垂直格式输出(由\g指定),这是经常有用的语句,以避免长线概括输出:

试试下面的例子:

mysql> show index from table_name\g
........

总结

以上所述是小编给大家介绍的mysql索引,希望对大家有所帮助

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网