ホームページ >データベース >mysql チュートリアル >SQL Server でのパラメーター スニッフィングによって引き起こされるストアド プロシージャのパフォーマンスの低下を解決するにはどうすればよいですか?

SQL Server でのパラメーター スニッフィングによって引き起こされるストアド プロシージャのパフォーマンスの低下を解決するにはどうすればよいですか?

Barbara Streisand
Barbara Streisandオリジナル
2024-12-31 15:58:17158ブラウズ

How Can I Resolve Poor Stored Procedure Performance Caused by Parameter Sniffing in SQL Server?

パラメータ スニッフィングによるストアド プロシージャのパフォーマンスの低下

入力パラメータ (@MyDate) が使用されるストアド プロシージャでパフォーマンスの問題が発生しています。 NULL または日付を指定できます。 @MyDate を NULL として最初にプロシージャをコンパイルすると、実際のパラメータ値に関係なく、その後の実行ではパフォーマンスが低下します。

パラメータ スニッフィング動作

SQL Server は「パラメータ」を実行しますスニッフィング」を使用して、コンパイル中のパラメータ値に基づいて実行計画を最適化します。これらの値をプロシージャ キャッシュにキャプチャし、将来の実行を推定するために使用します。

この場合、@MyDate が最初に NULL である場合、パラメータ スニッフィングはすべてのパラメータ値に対して次善の実行プランを生成するため、問題が発生しています。実行時に @MyDate が明示的に NULL に設定されている場合でも、キャッシュされたプランは残ります。

パラメーター スニッフィングの無効化

「パラメーター スニッフィング」という古典的な症状が発生しました。問題が発生しました。」では、初期パラメータ値に対して生成された計画が、実際の実行を表していない場合でも使用されます。パラメータ スニッフィングを無効にするには、@MyDate_Copy を使用してパラメータをスプーフィングしました。

根本原因と解決策

この問題は、パラメータ スニッフィングが誤動作する可能性がある SQL Server 2005 のバグに起因しています。 SQL Server 2008 では、OPTIMIZE FOR UNKNOWN オプションを使用することでこの問題を軽減できます。これにより、オプティマイザはプランのコンパイル中にパラメータのすべての可能な値を強制的に考慮します。

追加の洞察

  • 計画に影響を与える述語は、計画を引き起こす可能性がある複雑な式です
  • パラメータをマスクすると、パラメータ スニッフィングの問題を防ぐことができます。
  • 深刻な場合、OPTIMIZE FOR UNKNOWN を使用すると、オプティマイザにすべてのパラメータ値を強制的に考慮させることができます。
  • Microsoft のドキュメントを参照してください。パラメーター スニッフィング動作の詳細と最新情報については、

以上がSQL Server でのパラメーター スニッフィングによって引き起こされるストアド プロシージャのパフォーマンスの低下を解決するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。