집 >데이터 베이스 >MySQL 튜토리얼 >'ON DUPLICATE KEY UPDATE'를 사용하여 MySQL INSERT 쿼리를 어떻게 최적화할 수 있습니까?
"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 중국어 웹사이트의 기타 관련 기사를 참조하세요!