SQL 索引使用与优化全解析
1. 索引基础
1.1 外键索引说明
外键约束不会自动使用索引来实现,但为迁移的外键列创建索引通常对性能有益。若要删除索引,可使用如下语句:
DROP INDEX produce.vegetable.Xvegetable_consistency
1.2 基本索引使用
不同索引有不同的基本使用模式,同时可在查询计划中查看索引的使用情况:
- 聚集索引 :需考虑将哪些列用于聚集索引。
- 非聚集索引 :选定聚集索引后,要决定在何处应用非聚集索引。
- 唯一索引 :应尽可能频繁使用唯一索引。
查看查询计划可使用 SET SHOWPLAN ON
语句。本地操作时,使用 Management Studio 的图形化执行计划更便捷;若要分享计划或包含在文档中,可使用 SET SHOWPLAN_TEXT
命令。示例如下:
SET SHOWPLAN_TEXT ON
GO
SELECT *
FROM produce.vegetable
GO
SET SHOWPLAN_TEXT OFF
GO
运行上述语句后,会先将查询作为 StmtText
的单列结果集回显,然后返回显示计划的相同列名