> 데이터 베이스 > MySQL 튜토리얼 > MySQL에서 SQL의 MERGE 문의 기능을 어떻게 얻을 수 있습니까?

MySQL에서 SQL의 MERGE 문의 기능을 어떻게 얻을 수 있습니까?

Mary-Kate Olsen
풀어 주다: 2024-12-29 21:01:11
원래의
302명이 탐색했습니다.

How Can I Achieve the Functionality of SQL's MERGE Statement in MySQL?

MySQL의 MERGE 문 대안

SQL에는 사용자가 INSERT 및 UPDATE 작업을 단일 쿼리로 결합할 수 있는 병합 문이 포함되어 있습니다. 그러나 MySQL은 이 문을 지원하지 않습니다.

MySQL에서 병합 효과 달성

전용 MERGE 문이 없음에도 불구하고 MySQL은 대체 솔루션을 제공합니다.

중복 키에 삽입... UPDATE

이 구문을 사용하면 UNIQUE 또는 PRIMARY KEY 인덱스의 값이 이미 존재하는 경우 기존 행을 업데이트하는 동안 테이블에 새 행을 삽입할 수 있습니다. 새 행으로 인해 중복 값이 ​​발생하면 MySQL은 다음 단계를 실행합니다.

  1. 첫 번째 확인: MySQL은 먼저 기존 행이 고유한 행과 들어오는 행과 일치하는지 확인합니다. 기본 키.
  2. True인 경우 업데이트: 일치하는 항목이 발견되면 MySQL은 UPDATE에 지정된 새 값으로 기존 행을 업데이트합니다.
  3. 거짓인 경우 삽입: 일치하는 항목이 없으면 MySQL은 예상대로 새 행을 삽입합니다.

예:

INSERT INTO my_table (id, name, age)
VALUES (1, 'John Doe', 35)
ON DUPLICATE KEY UPDATE name = 'Jane Doe', age = 40;
로그인 후 복사

이 예에서 ID가 1인 행이 이미 존재하는 경우 MySQL은 이름은 'Jane Doe', 나이는 40입니다. 그렇지 않으면 지정된 값이 있는 새 행이 삽입됩니다.

위 내용은 MySQL에서 SQL의 MERGE 문의 기능을 어떻게 얻을 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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