>데이터 베이스 >MySQL 튜토리얼 >'ON DUPLICATE KEY UPDATE'를 사용하여 MySQL INSERT 쿼리를 어떻게 최적화할 수 있습니까?

'ON DUPLICATE KEY UPDATE'를 사용하여 MySQL INSERT 쿼리를 어떻게 최적화할 수 있습니까?

Patricia Arquette
Patricia Arquette원래의
2024-12-09 01:23:10296검색

How Can I Optimize MySQL INSERT Queries Using

"ON DUPLICATE KEY UPDATE"로 INSERT 쿼리 최적화

MySQL 데이터베이스 시스템은 시나리오를 처리하기 위해 "ON ​​DUPLICATE KEY UPDATE" 절을 제공합니다. 중복된 기본 키가 있는 레코드를 삽입하려고 하면 업데이트 작업이 트리거됩니다. 이 문서에서는 이 절을 활용하여 효율적이고 간결한 업데이트를 달성하는 방법을 살펴봅니다.

전체 필드 사양을 갖춘 표준 INSERT

중복 키가 있는 레코드를 삽입하려고 하면, "ON DUPLICATE KEY UPDATE"에서 모든 필드 값을 지정하는 방법을 사용할 수 있습니다. 절:

INSERT INTO table (id, a, b, c, d, e, f, g)
VALUES (1, 2, 3, 4, 5, 6, 7, 8)
ON DUPLICATE KEY UPDATE a=2, b=3, c=4, d=5, e=6, f=7, g=8;

이 접근 방식을 사용하면 모든 필드가 올바르게 업데이트되지만 초기 삽입 시 이미 제공되는 값을 중복 지정해야 합니다.

다음 필드 값 사용 INSERT 문

중복을 피하기 위해 "ON"에서 "VALUES()" 구문을 활용할 수 있습니다. DUPLICATE KEY UPDATE" 절:

INSERT INTO table (id, a, b, c, d, e, f, g)
VALUES (1, 2, 3, 4, 5, 6, 7, 8)
ON DUPLICATE KEY UPDATE a=VALUES(a), b=VALUES(b), c=VALUES(c),
                              d=VALUES(d), e=VALUES(e), f=VALUES(f), g=VALUES(g);

이 구문은 삽입 문의 원래 값을 참조하므로 값을 다시 지정할 필요가 없습니다.

중복 업데이트 및 LAST_INSERT_ID 고려 사항

기존 필드 값이 새 필드 값과 일치하면 MySQL이 어떤 업데이트도 수행하지 않습니다. 따라서 실제로 모든 필드를 "ON DUPLICATE KEY UPDATE" 절에 지정해야 하는지 여부를 고려하는 것이 중요합니다.

또한 LAST_INSERT_ID()에 의해 생성된 ID를 검색하려면 특정 백엔드에 따라 추가 처리가 필요할 수 있습니다. 사용 중인 애플리케이션 또는 미들웨어. 어떤 경우에는 마지막으로 삽입된 ID를 얻기 위해 데이터베이스를 별도로 쿼리해야 할 수도 있습니다.

위 내용은 'ON DUPLICATE KEY UPDATE'를 사용하여 MySQL INSERT 쿼리를 어떻게 최적화할 수 있습니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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