> 데이터 베이스 > MySQL 튜토리얼 > \'Delegates\' 테이블에 데이터를 삽입하는 동안 중복 값을 방지하는 방법은 무엇입니까?

\'Delegates\' 테이블에 데이터를 삽입하는 동안 중복 값을 방지하는 방법은 무엇입니까?

Susan Sarandon
풀어 주다: 2024-11-01 08:08:30
원래의
970명이 탐색했습니다.

How to Prevent Duplicate Values During Data Insertion in a

데이터 삽입 중 중복 값 방지

문제 설명:

"라는 테이블 내 고유한 구성원 정보와 범위 필드 "FromYr" 및 "ToYr"이 포함된 Delegates"에 사용자 입력을 사용한 데이터 삽입을 사용하면 같은 연도의 구성원이 중복될 위험이 있습니다.

해결책:

이 문제를 해결하고 데이터 무결성을 보장하기 위해 MERGE 문을 활용할 수 있습니다. MERGE 문을 사용하면 조건부 삽입을 수행하여 테이블 내에 레코드가 아직 존재하지 않는 경우에만 레코드를 업데이트할 수 있습니다.

구현:

<code class="sql">MERGE INTO Delegates D
USING (values(@MemNo, @FromYr,@ToYr)) X ([MemNo],[FromYr],[ToYr])
ON (insert unique key join)
WHEN NOT MATCHED BY TARGET THEN
INSERT ([MemNo],[FromYr],[ToYr]))
VALUES (X.[MemNo],X.[FromYr],X.[ToYr]);</code>
로그인 후 복사

설명:

  • MERGE INTO: 이 문은 업데이트하거나 삽입할 대상 테이블("Delegates")을 지정합니다.
  • USING: 이 절은 대상 테이블과 비교되는 원본 데이터("X")를 정의합니다.
  • ON: 조인 기준은 행이 일치해야 하는 조건을 지정합니다. 병합 작업 중. 이 경우 고유 키 조인(예: MemberNo 및 year)을 사용하여 행이 이미 존재하는지 식별합니다.
  • WHEN NOT MATCHED BY TARGET THEN: 이 문은 다음 작업을 정의합니다. 대상 테이블에 일치하는 행이 없으면 수행됩니다. 이 경우 새 행을 추가하기 위해 INSERT가 수행됩니다.

위 내용은 \'Delegates\' 테이블에 데이터를 삽입하는 동안 중복 값을 방지하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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