OPTION (RECOMPILE) のほうが速い理由: 説明
SQL Server のコンテキストでは、OPTION (RECOMPILE) 句はクエリのパフォーマンスを向上させる上で重要な役割を果たします。このオプションがリソースを大量に消費することは一般に理解されていますが、その基礎となるメカニズムを理解すると、このオプションを使用しないクエリよりも優れたパフォーマンスを発揮するシナリオが明らかになります。
プラン キャッシュとパラメーター スニッフィング
SQL Server でクエリが実行されると、データベースへのアクセスを最適化するために実行プランが生成されます。このプランは、クエリの実行中に使用される特定のパラメーターに基づいてキャッシュされます。ただし、データまたはパラメータ値が大幅に変更されると、キャッシュされたプランが最適ではなくなる可能性があります。
OPTION (RECOMPILE) の場合
特定の状況では、クエリを実行するたびに実行プランを再構築する利点は、再コンパイルに伴うパフォーマンスの低下を上回る可能性があります。これは特に次の場合に当てはまります:
注意事項とケーススタディ
その利点にもかかわらず、 OPTION (RECOMPILE) はむやみに使用しないでください。実行プランの定期的な再構築はリソースを大量に消費する可能性があり、不要なオーバーヘッドが発生する可能性があります。
上記のケースでは、OPTION (RECOMPILE) による大幅なパフォーマンスの向上は、古い統計に起因している可能性があります。 sp_updatestats コマンドを実行して統計を更新し、再コンパイルせずに実行プランを再作成すると、実行のたびに OPTION (RECOMPILE) を必要とせずにクエリのパフォーマンスを最適化できます。
結論
OPTION (RECOMPILE) は、動的 SQL または古い統計がクエリのパフォーマンスに影響を与える特定のシナリオで貴重なツールとして機能します。ただし、このオプションに頼る前に、再コンパイルを行わずに統計を再構築し、実行計画を最適化する方法を潜在的な解決策として検討する必要があります。
以上がOPTION (RECOMPILE) を使用すると SQL クエリが高速になるのはいつですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。