还有,什么时候使用手机比较合适?


当前回答

索引的使用有几个不同的原因。主要原因是为了加快查询速度,以便更快地获取行或对行进行排序。另一个原因是定义一个主键或唯一索引,这将保证没有其他列具有相同的值。

其他回答

索引的使用有几个不同的原因。主要原因是为了加快查询速度,以便更快地获取行或对行进行排序。另一个原因是定义一个主键或唯一索引,这将保证没有其他列具有相同的值。

索引用于加快在数据库中的搜索速度。MySQL有一些关于这个主题的很好的文档(也适用于其他SQL服务器): http://dev.mysql.com/doc/refman/5.0/en/mysql-indexes.html

索引可用于高效地查找查询中与某列匹配的所有行,然后仅遍历表的该子集以查找精确匹配。如果WHERE子句中的任何列上都没有索引,SQL server必须遍历整个表并检查每一行以查看是否匹配,这在大表上可能是一个缓慢的操作。

索引也可以是UNIQUE索引,这意味着在该列中不能有重复的值,也可以是PRIMARY KEY,在某些存储引擎中,PRIMARY KEY定义了值在数据库文件中的存储位置。

在MySQL中,你可以在SELECT语句前使用EXPLAIN来查看你的查询是否使用了任何索引。这是排除性能问题的良好开端。点击此处阅读更多信息: http://dev.mysql.com/doc/refman/5.0/en/explain.html

索引-轻松找到数据

UNIQUE INDEX -不允许重复的值

INDEX的语法

CREATE INDEX INDEX_NAME ON TABLE_NAME(COLUMN);

UNIQUE INDEX的语法

CREATE UNIQUE INDEX INDEX_NAME ON TABLE_NAME(COLUMN);

INDEX是一种性能优化技术,可以加速数据检索过程。它是与表(或视图)相关联的持久数据结构,以便在从表(或视图)检索数据时提高性能。

基于索引的搜索尤其适用于查询包含WHERE过滤器的情况。否则,即没有WHERE-filter的查询将选择整个数据和过程。在没有索引的情况下搜索整个表称为表扫描。

您将以清晰可靠的方式找到Sql-Indexes的确切信息: 点击以下链接:

从概念上理解: http://dotnetauthorities.blogspot.in/2013/12/Microsoft-SQL-Server-Training-Online-Learning-Classes-INDEX-Overview-and-Optimizations.html 对于实现方面的理解: http://dotnetauthorities.blogspot.in/2013/12/Microsoft-SQL-Server-Training-Online-Learning-Classes-INDEX-Creation-Deletetion-Optimizations.html

首先,我们需要了解正常(没有索引)查询是如何运行的。它基本上是逐个遍历每一行,当它找到数据时就返回。参考下图。(图片来自视频)

假设查询要找到50条记录,那么作为线性搜索,它必须读取49条记录。

参考下图。(图片来自视频)

当我们应用索引时,查询将快速找到数据,而不需要读取每个数据,只需要在每次遍历中消除一半的数据,就像二进制搜索一样。mysql索引存储为b -树,其中所有数据都在叶节点中。