>데이터 베이스 >MySQL 튜토리얼 >중복 키 처리를 사용하여 MySQL에서 Upsert를 효율적으로 수행하려면 어떻게 해야 합니까?

중복 키 처리를 사용하여 MySQL에서 Upsert를 효율적으로 수행하려면 어떻게 해야 합니까?

Susan Sarandon
Susan Sarandon원래의
2024-12-08 13:41:111028검색

How Can I Efficiently Perform Upserts in MySQL with Duplicate Key Handling?

중복 키 업데이트를 위한 효율적인 Upsert 쿼리

고유 인덱스가 있는 MySQL 테이블에 데이터를 삽입할 때 기존 인덱스를 업데이트해야 하는 경우가 많습니다. 키가 이미 존재하는지 기록하십시오. 이를 달성하기 위해 일반적으로 "ON DUPLICATE KEY UPDATE" 절을 사용하여 수정할 필드를 지정합니다. 그러나 모든 필드를 다시 지정하는 것은 비효율적일 수 있습니다.

대체 구문

더 간단한 접근 방식은 아래와 같이 VALUES() 함수를 사용하는 것입니다.

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);

이 구문을 사용하면 각 필드를 두 번 지정할 필요가 없으므로 쿼리가 더 많아집니다. 간결합니다.

업데이트 방지 고려

이미 가지고 있는 동일한 값으로 필드를 업데이트할 필요가 없다는 점에 유의하는 것이 중요합니다. 기존 레코드에 이미 삽입과 동일한 데이터가 포함되어 있는 경우 업데이트를 수행할 필요가 없습니다. 불필요한 업데이트를 방지하려면 다음 구문을 사용할 수 있습니다.

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=a, b=b, c=c, d=d, e=e, f=f, g=g;

마지막 삽입 ID 검색

새로 삽입되거나 업데이트된 레코드의 ID를 얻으려면 구문은 사용되는 백엔드 앱에 따라 다릅니다. 예를 들어 LuaSQL에서는 conn:getlastautoid() 함수를 사용하여 값을 검색할 수 있습니다.

위 내용은 중복 키 처리를 사용하여 MySQL에서 Upsert를 효율적으로 수행하려면 어떻게 해야 합니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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