数据库索引是一个数据结构,提高操作的速度,在一个表中可以使用一个或多个列,提供两个快速随机查找和高效的顺序访问记录的基础创建索引。
在创建索引时,它应该被认为是将SQL查询的那些列上创建一个或多个索引的列。
实际上,指数也保持主键或索引字段和指针的实际表中每条记录的表型。
用户无法看到索引,它们只是用来加快查询速度,将用于数据库搜索引擎找到的记录速度非常快。
INSERT和UPDATE语句表上的索引需要更多的时间,成为快速对这些表的SELECT语句。究其原因是,当进行插入或更新,数据库以及需要惰性或更新索引值。
简单的唯一索引:
可以创建一个唯一索引的表。唯一的索引意味着两个行不能拥有相同的索引值。这里是语法来创建索引的表
CREATE UNIQUE INDEX index_name ON table_name ( column1, column2,...);
可以使用一个或多个列上创建索引。例如,我们可以创建一个索引的使用在表tutorials_tbl的tutorial_author列上
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命令添加和删除索引:
有四种类型的语句表添加索引:
下面是这个例子,在现有的表添加索引。
mysql> ALTER TABLE testalter_tbl ADD INDEX (c);
可以删除任何INDEX通过使用DROP子句和使用ALTER命令。试试下面的例子上面创建的索引下降。
mysql> ALTER TABLE testalter_tbl DROP INDEX (c);
可以删除任何INDEX通过使用DROP子句t和使用ALTER命令。试试下面的例子上面创建的索引x。
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;
要删除索引,这不是一个PRIMARY KEY,所以必须指定索引的名称。
显示索引信息:
您可以使用SHOW INDEX命令,列出所有相关联的索引表。垂直格式输出(指定由\ G)往往是有用的这句话,以避免长时间行重叠:
试试下面的例子:
mysql> SHOW INDEX FROM table_name\G ........
本文向大家介绍简单介绍下MYSQL的索引类型,包括了简单介绍下MYSQL的索引类型的使用技巧和注意事项,需要的朋友参考一下 一、介绍一下索引的类型 Mysql常见索引有:主键索引、唯一索引、普通索引、全文索引、组合索引 PRIMARY KEY(主键索引) ALTER TABLE `table_name` ADD PRIMARY KEY ( `column` ) UNIQUE(唯一索引) ALTER
本文向大家介绍简单介绍MySQL中GROUP BY子句的使用,包括了简单介绍MySQL中GROUP BY子句的使用的使用技巧和注意事项,需要的朋友参考一下 可以使用GROUP BY组值一列,并且如果愿意的话,可以将该列进行计算。使用COUNT,SUM,AVG等功能的分组列。 要了解GROUP BY子句考虑的EMPLOYEE_TBL的的表具有以下记录: 现在,假设根据上表,我们希望计算每一位员工工
本文向大家介绍Mysql索引详细介绍,包括了Mysql索引详细介绍的使用技巧和注意事项,需要的朋友参考一下 Mysql索引概述 所有MySQL列类型可以被索引。对相关列使用索引是提高SELECT操作性能的最佳途径。根据存储引擎定义每个表的最大索引数和最大索引长度。所有存储引擎支持每个表至少16个索引,总索引长度至少为256字节。大多数存储引擎有更高的限制。 在MySQL 5.1中,对于MyISAM
本文向大家介绍MySQL索引之聚集索引介绍,包括了MySQL索引之聚集索引介绍的使用技巧和注意事项,需要的朋友参考一下 在MySQL里,聚集索引和非聚集索引分别是什么意思,有什么区别? 在MySQL中,InnoDB引擎表是(聚集)索引组织表(clustered index organize table),而MyISAM引擎表则是堆组织表(heap organize table)。 也有人把聚集索引
本文向大家介绍MySQL中decimal类型用法的简单介绍,包括了MySQL中decimal类型用法的简单介绍的使用技巧和注意事项,需要的朋友参考一下 MySQL中支持浮点数的类型有FLOAT、DOUBLE和DECIMAL类型,DECIMAL 类型不同于FLOAT和DOUBLE,DECIMAL 实际是以串存放的。DECIMAL 可能的最大取值范围与DOUBLE 一样,但是其有效的取值范围由M 和D
本文向大家介绍java ThreadPoolExecutor使用方法简单介绍,包括了java ThreadPoolExecutor使用方法简单介绍的使用技巧和注意事项,需要的朋友参考一下 java ThreadPoolExecutor 前言: 在项目中如果使用发短信这个功能,一般会把发短信这个动作变成异步的,因为大部分情况下,短信到底是发送成功或者失败,都不能影响主流程。当然像发送MQ消息等