查询类型和索引
当您考虑是否要对列创建索引时,请估计在查询中使用列的方式。下表介绍了索引对其有用的查询类型。
注意 |
---|
表中的示例基于 AdventureWorks2008R2 示例数据库。在 SQL Server Management Studio 中运行这些示例时,您可以通过显示实际的执行计划来查看查询优化器选择的索引。有关详细信息,请参阅如何显示实际执行计划。 |
列谓词为下列之一的查询 |
查询说明和示例 |
考虑的索引 |
---|---|---|
与特定值完全匹配 |
搜索与特定值完全匹配的项,其中,查询使用 WHERE 子句指定列项。例如:
|
BusinessEntityID 列的非聚集或聚集索引。 |
与 IN (x,y,z) 列表中的某个值完全匹配 |
搜索与指定值列表中的某个值完全匹配的项。例如:
|
BusinessEntityID 列的非聚集或聚集索引。 |
值范围 |
搜索某个值范围,其中,查询指定的任何项的值在两个值之间。例如:
或
|
ProductModelID 列的聚集索引或非聚集索引。 |
表之间的联接 |
基于联接谓词,在一个表中搜索与另一个表中的某个行匹配的行。例如:
|
ProductID 和 ProductAssemblyID 列的聚集索引或非聚集索引。 |
LIKE 比较 |
搜索以特定字符串(如 abc%)开头的匹配行。例如:
|
Name 列的非聚集或聚集索引。 |
排序或聚合 |
需要隐式或显式排序顺序或聚合 (GROUP BY)。例如:
|
排序列或聚合列的非聚集索引或聚集索引。 对于排序列,考虑为列指定 ASC 或 DESC 顺序。 |
PRIMARY KEY 或 UNIQUE 约束 |
搜索与插入和更新操作中的新索引键值重复的值,以强制 PRIMARY KEY 和 UNIQUE 约束。例如:
|
约束中定义的列的聚集索引或非聚集索引。 |
PRIMARY KEY/FOREIGN KEY 关系中的 UPDATE 或 DELETE 操作 |
在列参与 PRIMARY KEY/FOREIGN KEY 关系(无论带不带 CASCADE 选项)的更新或删除操作中搜索行。 |
外键列的非聚集索引或聚集索引。 |
列在选择列表中,但不在谓词中。 |
包含选择列表中未用于搜索和查找的一列或多列。例如:
|
在 INCLUDE 子句中指定了 FileName 的非聚集索引。 |