自動インクリメント主キーのギャップ: 説明
自動インクリメント主キーを使用すると、割り当てられたキーのシーケンスにギャップが発生するのが一般的です。 ID。これは、削除せずに挿入を実行した場合でも発生する可能性があります。この理由は、MySQL のトランザクション処理とロールバックの可能性によるものです。
この問題を説明するために、挿入を実行する 2 つの重複するトランザクションを考えてみましょう。
トランザクション 1 が失敗してロールバックすると、ID 42 は未使用になります。ただし、トランザクション 2 は依然として完了し、ID 43 が割り当てられます。このシナリオではシーケンスにギャップが生じ、ID 42 が未使用のままになります。
MySQL のスケーラビリティへの取り組みが、この動作の根本的な理由です。連続した値が保証されている場合、すべてのトランザクションは順番に発生する必要があり、大量のデータを処理するときにパフォーマンスに影響を及ぼします。
ID シーケンスのギャップの影響を軽減するには、サロゲート キーまたはカスタム キーの使用を検討してください。連続した値を保証するロジック。ただし、自動インクリメント主キーのギャップは MySQL のトランザクション処理に固有の機能であり、アプリケーションの機能に影響を与えない限り、心配する必要はありません。
以上がMySQL で自動インクリメント主キーにギャップがあるのはなぜですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。