ホームページ >データベース >mysql チュートリアル >複合主キーは MySQL InnoDB テーブルのパフォーマンスに影響しますか?
MySQL における複合主キーのパフォーマンスへの影響
MySQL データベースでは、テーブルは多くの場合、行を一意に識別するために主キーを利用します。大量のデータを含むテーブルを操作する場合、挿入操作と選択操作の両方のパフォーマンスを最適化することが重要になります。複合主キーがパフォーマンスに与える影響に関してよくある質問が 1 つあります。
複数のフィールドで構成される複合主キーは、InnoDB テーブルでの挿入および選択操作のパフォーマンスに影響しますか?
この質問に答えるために、2 つのシナリオを考えてみましょう:
このシナリオでは、主キーkey は複数の列を使用して定義され、複合インデックスを作成します。このシナリオでの挿入と更新は、通常、単純な自動インクリメント整数主キーと比較して、パフォーマンスの違いが最小限に抑えられます。影響は比較的無視できます。
単一の自動インクリメント整数を主キーとして使用する場合パフォーマンスの点でより良いオプションのように思えます。ただし、InnoDB テーブルの場合、このアプローチには 2 番目の検索ステップが必要になります。インデックス内の値を見つけた後、エンジンはテーブル自体の ID による追加の検索を実行する必要があります。
選択のパフォーマンスに関する重要な考慮事項
挿入のパフォーマンスは向上しません。主キーの選択によって大きく影響されるため、選択のパフォーマンスはテーブル構造とクエリ タイプによって異なる場合があります。
InnoDB テーブルが複合主キーを使用して作成されている場合、テーブルは本質的にそのキー値に基づいてクラスター化されます。主キーの両方の値を検索する場合は、追加のキー検索が必要ないため、より高速になります。
逆に、自動インクリメントフィールドが主キーとして使用されている場合、データベース エンジンは最初にインデックスを参照する必要があります。行ポインター (ID の値) を取得し、テーブル内の ID による検索を実行します。これにより、プロセスに余分なステップが追加される可能性があります。
結論として、挿入操作の場合、複合主キー間のパフォーマンスの違いは次のとおりです。自動インクリメントされる ID フィールドは無視できます。ただし、InnoDB テーブルの場合、クエリに主キーを構成する列の値の検索が含まれる場合、複合主キーにより選択パフォーマンスが向上します。
以上が複合主キーは MySQL InnoDB テーブルのパフォーマンスに影響しますか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。