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

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

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

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

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

简单和唯一索引

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

CREATE UNIQUE INDEX index_nameON table_name ( column1, column2,...);
CREATE UNIQUE INDEX AUTHOR_INDEXON tutorials_tbl (tutorial_author)

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

mysql> CREATE UNIQUE INDEX AUTHOR_INDEXON tutorials_tbl (tutorial_author DESC)

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

  • 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);
mysql> ALTER TABLE testalter_tbl DROP INDEX (c);

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

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

mysql> ALTER TABLE testalter_tbl MODIFY i INT NOT NULL;mysql> ALTER TABLE testalter_tbl ADD PRIMARY KEY (i);
mysql> ALTER TABLE testalter_tbl DROP PRIMARY KEY;

显示索引信息

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

试试下面的例子:

mysql> SHOW INDEX FROM table_name\G........

更多相关文章

  1. MySQL系列多表连接查询92及99语法示例详解教程
  2. Linux下MYSQL 5.7 找回root密码的问题(亲测可用)
  3. MySQL 什么时候使用INNER JOIN 或 LEFT JOIN
  4. [android源码下载索引贴】微信+二维码那都不是事......
  5. android从服务器下载文件(php+apache+win7+MySql)
  6. 【有图】android通过jdbc连接mysql(附文件)
  7. android触控,先了解MotionEvent
  8. 系出名门 Android(安卓)系列文章索引
  9. 系出名门 Android(安卓)系列文章索引

随机推荐

  1. 分享20个Android游戏源码,希望大家喜欢哈!
  2. android显示PNG图片背景黑色问题 ImageVi
  3. Android(安卓)APP跳转微信小程序和APP跳
  4. android 环境搭建 windows 和linux 环境
  5. android loader用法
  6. Android P SystemUI之StatusBar Wifi图标
  7. Android判断输入是否只包含数字并且执行
  8. Mac 下完全卸载Android Studio 和SDK
  9. android apache HTTP demo 互联网访问
  10. Ubuntu编译Android整个系统以及编译指定