> 데이터 베이스 > MySQL 튜토리얼 > 중복 항목을 피하기 위해 MySQL에서 조건부 삽입을 수행하는 방법은 무엇입니까?

중복 항목을 피하기 위해 MySQL에서 조건부 삽입을 수행하는 방법은 무엇입니까?

Linda Hamilton
풀어 주다: 2024-12-13 09:54:14
원래의
537명이 탐색했습니다.

How to Perform Conditional Inserts in MySQL to Avoid Duplicate Entries?

MySQL의 조건부 삽입

조건부 INSERT 문을 사용하면 특정 조건이 있는 테이블에 데이터를 삽입할 수 있습니다. 이는 중복 항목을 방지하거나 데이터 무결성을 보장하려는 경우 특히 유용합니다. 그러한 시나리오 중 하나는 지정된 사용자가 특정 항목을 아직 소유하지 않은 경우에만 새 행을 삽입하는 것입니다.

MySQL에서 조건부 삽입을 수행하려면 다음 단계를 고려하십시오.

  • 열(인스턴스, 사용자, 항목)이 있는 x_table 생성: 인스턴스 열에 중복을 방지하기 위한 고유 인덱스가 있는지 확인하세요. 항목.
  • 조건부 INSERT 문 작성: 지정된 조건이 충족되는 경우에만 새 행을 삽입하려면 다음 구문을 사용하십시오.
INSERT INTO x_table (instance, user, item) 
SELECT <instance_value>, <user_value>, <item_value>
FROM dual
WHERE NOT EXISTS (SELECT * FROM x_table
                     WHERE user = <user_value> 
                       AND item = <item_value>)
로그인 후 복사
  • 자리 표시자 바꾸기: 바꾸기, 삽입하려는 실제 값으로. 예를 들어, 인스턴스=919191, 사용자=123, 항목=456을 삽입하려면 명령문은 다음과 같습니다.
INSERT INTO x_table (instance, user, item) 
SELECT 919191, 123, 456
FROM dual
WHERE NOT EXISTS (SELECT * FROM x_table
                     WHERE user = 123 
                       AND item = 456)
로그인 후 복사

이 명령문은 사용자=123의 조합인 경우에만 새 행을 삽입합니다. item=456은 x_table에 아직 존재하지 않습니다. 그러한 행이 있으면 삽입을 건너뜁니다.

  • 추가 사용: DBMS가 삽입 중에 다른 테이블에서 선택하는 것을 제한하는 경우 다음과 같이 MERGE 문을 탐색할 수 있습니다. 조건부 INSERT의 대안.

위 내용은 중복 항목을 피하기 위해 MySQL에서 조건부 삽입을 수행하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿