SQL Server の自動パラメーター化プロセスにより、複数の INSERT ステートメントは、複数の VALUES を含む単一の INSERT よりもパフォーマンスが優れています。
複数の INSERT ステートメントの場合、各ステートメントはコンパイルされ実行されます。独立して実行されるため、オーバーヘッドは最小限に抑えられます。ただし、複数の VALUES を含む 1 つの INSERT ステートメントの場合、クエリ オプティマイザーは実行前にステートメント全体を解析してコンパイルする必要があるため、コンパイル時間が大幅に長くなる可能性があります。
自動パラメーター化のカットオフは 250 VALUES 句あたりで発生します。この点を超えると、キャッシュされたプランのサイズが急激に減少し、コンパイル時間が大幅に増加し、値句の処理効率が直線的に低下します。
この動作は、プラン タイプの変更に起因します。自動パラメータ化を使用する場合、プランは挿入されるリテラル値に固有です。制限を超えると、プランはパラメータ化されなくなり、並べ替えなどの線形にスケールしないアクティビティを実行する必要があり、その結果、コンパイル時間が長くなります。
これによる影響は、特に重大になる可能性があります。長い文字列または一意の値を扱う場合。グラフで示されているように、文字列の長さを増やすか重複を削除すると、複数の VALUES メソッドを使用した単一の INSERT ステートメントのパフォーマンスが低下します。
逆に、重複を導入すると、SQL Server が代数化段階で重複を識別して回避できるため、パフォーマンスが向上します。
したがって、複数の行を挿入する場合、複数の INSERT ステートメントを使用する方が、単一の INSERT ステートメントに複数の行を挿入するよりも効率的です。 VALUES、特に長い文字列または一意の値を扱う場合。
以上がSQL Server で複数の INSERT ステートメントが、複数の VALUES を含む 1 つの INSERT ステートメントより速いのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。