还有,什么时候使用手机比较合适?
当前回答
首先,我们需要了解正常(没有索引)查询是如何运行的。它基本上是逐个遍历每一行,当它找到数据时就返回。参考下图。(图片来自视频)
假设查询要找到50条记录,那么作为线性搜索,它必须读取49条记录。
参考下图。(图片来自视频)
当我们应用索引时,查询将快速找到数据,而不需要读取每个数据,只需要在每次遍历中消除一半的数据,就像二进制搜索一样。mysql索引存储为b -树,其中所有数据都在叶节点中。
其他回答
聚集索引类似于电话簿的内容。你可以在“希尔迪奇,大卫”上打开这本书,找到所有希尔迪奇酒店的所有信息。这里聚集索引的键是(lastname, firstname)。
这使得聚集索引非常适合基于范围查询检索大量数据,因为所有数据都位于彼此相邻的位置。
由于聚集索引实际上与数据的存储方式有关,所以每个表只能使用一个索引(尽管可以模拟多个聚集索引)。
非聚集索引的不同之处在于,您可以有许多索引,然后它们指向聚集索引中的数据。例如,你可以在电话簿的后面有一个非聚集索引,键值为(城镇,地址)
想象一下,如果你必须在电话簿中搜索所有住在“伦敦”的人——只有聚类索引,你必须搜索电话簿中的每一个项目,因为聚类索引上的键是on(姓,名),因此生活在伦敦的人随机分散在索引中。
如果在(town)上有非聚集索引,则可以更快地执行这些查询。
索引用于加快查询的性能。它通过减少必须访问/扫描的数据库数据页的数量来实现这一点。
在SQL Server中,聚集索引决定了表中数据的物理顺序。每个表只能有一个聚集索引(聚集索引就是表)。表上的所有其他索引都称为非聚集索引。
SQL Server索引基础 SQL Server索引基础 SQL Server索引 指数基本知识 指数(维基)
首先,我们需要了解正常(没有索引)查询是如何运行的。它基本上是逐个遍历每一行,当它找到数据时就返回。参考下图。(图片来自视频)
假设查询要找到50条记录,那么作为线性搜索,它必须读取49条记录。
参考下图。(图片来自视频)
当我们应用索引时,查询将快速找到数据,而不需要读取每个数据,只需要在每次遍历中消除一半的数据,就像二进制搜索一样。mysql索引存储为b -树,其中所有数据都在叶节点中。
索引的使用有几个不同的原因。主要原因是为了加快查询速度,以便更快地获取行或对行进行排序。另一个原因是定义一个主键或唯一索引,这将保证没有其他列具有相同的值。
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
推荐文章
- 如何在Ruby On Rails中使用NuoDB手动执行SQL命令
- 查询JSON类型内的数组元素
- 确定记录是否存在的最快方法
- 获得PostgreSQL数据库中当前连接数的正确查询
- 在SQL选择语句Order By 1的目的是什么?
- 我如何循环通过一组记录在SQL Server?
- 如何从命令行通过mysql运行一个查询?
- 外键约束可能导致循环或多条级联路径?
- 使用LIMIT/OFFSET运行查询,还可以获得总行数
- 当恢复sql时,psql无效命令\N
- 货币应该使用哪种数据类型?
- 如何选择每一行的列值不是独特的
- 如何改变字符集(和排序)在整个数据库?
- mySQL:: insert到表,数据从另一个表?
- 如何在Postgres中获得两个字段的MIN() ?