>백엔드 개발 >PHP 튜토리얼 >MySQL 삽입 중 중복 항목 오류를 처리하는 방법은 무엇입니까?

MySQL 삽입 중 중복 항목 오류를 처리하는 방법은 무엇입니까?

Linda Hamilton
Linda Hamilton원래의
2024-10-26 23:40:30322검색

How to Handle Duplicate Entry Errors During MySQL Inserts?

MySQL 삽입 중 중복 항목 오류 처리

고유 필드가 있는 MySQL 데이터베이스에 데이터를 삽입할 때 중복 항목을 처리하는 것이 바람직한 경우가 많습니다. 오류 없이 정상적으로 항목을 입력할 수 있습니다. 이 문서에서는 삽입 중 중복 항목 오류를 무시하는 다양한 접근 방식을 살펴봅니다.

INSERT...IGNORE

INSERT...IGNORE 구문을 사용하면 다음 항목을 삽입할 수 있습니다. 잠재적인 중복 오류를 무시하고 테이블에 기록합니다. 동일한 고유 필드 값을 가진 항목이 존재하는 경우 오류를 발생시키지 않고 삽입을 건너뜁니다.

REPLACE INTO

REPLACE INTO 구문은 다음과 유사합니다. INSERT...IGNORE이지만 동일한 고유 필드 값으로 기존 레코드를 덮어씁니다. 이는 이전 레코드를 새 레코드로 바꾸려는 경우 유용할 수 있습니다.

INSERT...ON DUPLICATE KEY UPDATE

INSERT... ON DUPLICATE KEY UPDATE 구문을 사용하면 중복 항목이 발생할 때 수행할 작업을 지정할 수 있습니다. 기존 레코드를 새 값으로 업데이트하거나, 특정 열에 새 값을 설정하거나, 다른 작업을 수행하도록 선택할 수 있습니다.

다음을 고려하세요. 고유 열 "id"가 있는 다음 표:

id value
1 1

이 메소드의 기능을 보여주기 위해:

  • REPLACE INTO:
<code class="sql">REPLACE INTO tbl VALUES (1, 50);</code>

이렇게 하면 id=1인 기존 레코드가 새 값 value=50으로 대체됩니다.

  • INSERT IGNORE:
<code class="sql">INSERT IGNORE INTO tbl VALUES (1, 10);</code>

중복 항목을 무시하고 테이블을 변경하지 않습니다.

  • INSERT...ON DUPLICATE KEY UPDATE:
<code class="sql">INSERT INTO tbl VALUES (1, 200) ON DUPLICATE KEY UPDATE value=200;</code>

그러면 id=1인 기존 레코드가 값=200으로 업데이트됩니다.

위 내용은 MySQL 삽입 중 중복 항목 오류를 처리하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

성명:
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.