问题描述
我有一张约有500万条记录的表,每天都会更新/插入该表。 我需要添加一些索引以加快查询速度,是否建议将其添加到表本身或该表的视图上? 在获取数据并将其显示在网站上时,我所有的查询都在视图上方。
解决方法
即使您正在创建索引视图,由于基表上的常规插入/更新操作也会影响性能,因为索引也需要更新,因此需要权衡这点,以衡量创建后看到的性能提升索引视图,以及在基表上进行插入/更新操作时性能会降低多少。
我在下面引用了SQL Server官方文档
”“在由大量索引视图或较少但非常复杂的索引视图引用的表上执行DML时,也必须更新那些引用的索引视图。结果,DML查询性能可能会大大降低,或者在某些情况下甚至无法生成查询计划。在这种情况下,请在生产使用前测试DML查询,分析查询计划并调整/简化DML语句。”