由于参数嗅探导致存储过程性能较差
您遇到了存储过程的性能问题,其中输入参数 (@MyDate)可以是 NULL 或日期。当过程首次使用 @MyDate 为 NULL 进行编译时,无论实际参数值如何,后续执行都会表现出较差的性能。
参数嗅探行为
SQL Server 执行“参数嗅探”以在编译期间根据参数值优化执行计划。它捕获过程缓存中的这些值并使用它们来估计未来的执行。
在这种情况下,参数嗅探会导致问题,因为当 @MyDate 最初为 NULL 时,它会为所有参数值生成次优执行计划。即使在执行时将 @MyDate 显式设置为 NULL,缓存的计划仍然保留。
禁用参数嗅探
您遇到了“参数嗅探”的典型症状变坏了”,其中为初始参数值生成的计划即使不代表实际执行也会被使用。要禁用参数嗅探,您可以使用 @MyDate_Copy 欺骗参数。
根本原因和解决方案
此问题源于 SQL Server 2005 错误,参数嗅探可能会出现错误行为。在 SQL Server 2008 中,您可以通过使用 OPTIMIZE FOR UNKNOWN 选项来缓解此问题,该选项强制优化器在计划编译期间考虑参数的所有可能值。
其他见解
以上是如何解决SQL Server参数嗅探导致存储过程性能不佳的问题?的详细内容。更多信息请关注PHP中文网其他相关文章!