ホームページ >データベース >mysql チュートリアル >MySQL の挿入中に重複エントリを処理するにはどうすればよいですか?

MySQL の挿入中に重複エントリを処理するにはどうすればよいですか?

Linda Hamilton
Linda Hamiltonオリジナル
2024-12-04 21:15:13645ブラウズ

How to Handle Duplicate Entries During MySQL Insertion?

重複エントリ処理による MySQL 挿入

一意のフィールドを持つ MySQL データベースに新しいレコードを挿入すると、「重複エントリ」エラーが発生するのが一般的です。このようなエラーを適切に処理するには、いくつかの方法があります。

INSERT IGNORE

INSERT ... IGNORE 構文を使用すると、重複レコードを挿入しようとするときのエラーを防ぐことができます。挿入はエラー メッセージなしでスキップされます。

REPLACE INTO

INSERT IGNORE とは異なり、REPLACE INTO は新しいレコードを挿入する前に、同じ主キーを持つ既存のレコードを削除します。これにより、テーブルには一意のキーごとに 1 つのレコードのみが含まれるようになります。

INSERT ... ON DUPLICATE KEY UPDATE

この構文を使用すると、新しいレコードを挿入する代わりに、既存のレコードの更新を実行できます。 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 サイトの他の関連記事を参照してください。

声明:
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。