在SQL中的表或视图上添加索引

问题描述

我有一张约有500万条记录的表,每天都会更新/插入该表。 我需要添加一些索引以加快查询速度,是否建议将其添加到表本身或该表的视图上? 在获取数据并将其显示在网站上时,我所有的查询都在视图上方。

解决方法

即使您正在创建索引视图,由于基表上的常规插入/更新操作也会影响性能,因为索引也需要更新,因此需要权衡这点,以衡量创建后看到的性能提升索引视图,以及在基表上进行插入/更新操作时性能会降低多少。

我在下面引用了SQL Server官方文档

”“在由大量索引视图或较少但非常复杂的索引视图引用的表上执行DML时,也必须更新那些引用的索引视图。结果,DML查询性能可能会大大降低,或者在某些情况下甚至无法生成查询计划。在这种情况下,请在生产使用前测试DML查询,分析查询计划并调整/简化DML语句。”

相关问答

依赖报错 idea导入项目后依赖报错,解决方案:https://blog....
错误1:代码生成器依赖和mybatis依赖冲突 启动项目时报错如下...
错误1:gradle项目控制台输出为乱码 # 解决方案:https://bl...
错误还原:在查询的过程中,传入的workType为0时,该条件不起...
报错如下,gcc版本太低 ^ server.c:5346:31: 错误:‘struct...