一意のフィールドを持つ MySQL データベースに新しいレコードを挿入すると、「重複エントリ」エラーが発生するのが一般的です。このようなエラーを適切に処理するには、いくつかの方法があります。
INSERT ... IGNORE 構文を使用すると、重複レコードを挿入しようとするときのエラーを防ぐことができます。挿入はエラー メッセージなしでスキップされます。
INSERT IGNORE とは異なり、REPLACE INTO は新しいレコードを挿入する前に、同じ主キーを持つ既存のレコードを削除します。これにより、テーブルには一意のキーごとに 1 つのレコードのみが含まれるようになります。
この構文を使用すると、新しいレコードを挿入する代わりに、既存のレコードの更新を実行できます。 1つ。これは、既存のデータを保持しながら特定の列の値を更新するシナリオに役立ちます。
id と value の 2 つの列を持つテーブル tbl を考えてみましょう。 id=1、value=1 のレコードが 1 つあると仮定します。
REPLACE INTO:
REPLACE INTO tbl (id, value) VALUES (1, 50);
これは次のようになります。 id=1 の単一レコードとvalue=50.
INSERT IGNORE:
INSERT IGNORE INTO tbl (id, value) VALUES (1, 10);
既にレコードがあるためアクションはありません。 id=1.
INSERT ... ON DUPLICATE KEY UPDATE:
INSERT INTO tbl (id, value) VALUES (1, 200) ON DUPLICATE KEY UPDATE value=200;
これにより、id=1 の既存のレコードが更新されますvalue=200 を持つようにします。
以上がMySQL の挿入中に重複エントリを処理するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。