テーブルに重複行を挿入すると、MySQL の自動インクリメント メカニズムで予期しない動作が発生する可能性があります。 MySQL 5.1.49 では、INSERT IGNORE ステートメントが使用されている場合でも、自動インクリメント ID はインクリメントされ続けます。これにより、ID シーケンスに望ましくないギャップが生じる可能性があります。
この問題を解決するには、次の戦略を採用できます:
INSERT INTO tablename (tag) SELECT $tag FROM tablename WHERE NOT EXISTS( SELECT tag FROM tablename WHERE tag = $tag ) LIMIT 1
このステートメントは、まずタグがテーブルにすでに存在するかどうかを確認します。そうでない場合は、自動インクリメント メカニズムをトリガーせずに行が挿入されます。サブクエリにより、挿入が 1 回だけ行われることが保証されます。
これらのソリューションはすべてのシナリオに適しているわけではないことに注意することが重要です。パフォーマンスが懸念される場合は、別のテーブルを使用して一意の値を保存し、それらをメイン テーブルで参照するなど、他のオプションを評価する必要がある場合があります。
以上がMySQL に重複行を挿入するときに自動増分ギャップを防ぐにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。