MySQL での自動インクリメントの断片化への対処
MySQL の自動インクリメント主キーは、行が削除されると断片化され、キーにギャップが残ることがあります。 ID シーケンス。これにより、ID を参照として使用するときにパフォーマンスの問題や複雑さが発生する可能性があります。
ギャップを避ける
断片化を防ぐには、次のような別の主キー戦略を採用することを検討してください。グローバル一意識別子 (GUID) または自然キー。あるいは、レコードを物理的に削除するのではなく、レコードを削除済みとしてマークして、ギャップがないようにすることもできます。
自動インクリメント値の再順序付け
断片化がすでに発生している場合は、自動インクリメント値を現在の最大値に 1 を加えた値に手動でリセットできます。これは、次のクエリを使用して実現できます。
ALTER TABLE table_name AUTO_INCREMENT = MAX(id) + 1;
新しい自動インクリメント値の取得
新しい自動インクリメント値を取得するには、 LAST_INSERT_ID() 関数:
SELECT LAST_INSERT_ID() AS new_auto_increment_value;
これらのステップを 1 つに結合するALTER TABLE ステートメントと SELECT ステートメントは同じトランザクション内で互換性がないため、クエリは実行できません。
以上がMySQL での自動インクリメントの断片化に対処するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。