>데이터 베이스 >MySQL 튜토리얼 >ON DUPLICATE KEY를 사용하여 MySQL INSERT/UPDATE 후 행 ID를 얻는 방법은 무엇입니까?

ON DUPLICATE KEY를 사용하여 MySQL INSERT/UPDATE 후 행 ID를 얻는 방법은 무엇입니까?

Barbara Streisand
Barbara Streisand원래의
2024-12-05 08:51:13566검색

How to Get the Row ID After a MySQL INSERT/UPDATE with ON DUPLICATE KEY?

MySQL ON DUPLICATE KEY를 사용하여 INSERT/UPDATE 후 행 ID를 검색하는 방법

ON DUPLICATE KEY를 사용하여 데이터 삽입 또는 업데이트 MySQL의 절은 중복 키 오류를 처리하는 편리한 방법이 될 수 있습니다. 그러나 작업 후에 영향을 받은 행의 ID를 얻는 것이 어려울 수 있습니다.

한 가지 일반적인 가정은 LAST_INSERT_ID() 함수가 새로 삽입된 행의 ID만 반환한다는 것입니다. 그러나 ON DUPLICATE KEY 시나리오에서는 행이 수정된 경우 업데이트된 ID를 반환할 수도 있습니다.

해결 방법: LAST_INSERT_ID(expr)

LAST_INSERT_ID를 만들려면 () 삽입과 업데이트 모두에 의미가 있으며 MySQL은 다음을 제공합니다. 해결 방법:

INSERT INTO table (a,b,c) VALUES (1,2,3)
ON DUPLICATE KEY UPDATE>

이 예에서는 id 열이 AUTO_INCREMENT 기본 키로 가정됩니다. 업데이트 시 LAST_INSERT_ID(id)를 id 열에 할당하면 함수가 업데이트된 ID를 반환합니다.

마지막 삽입/업데이트 ID 검색

해결 방법이 적용되면 삽입된 행의 ID를 검색하려면 LAST_INSERT_ID() 함수를 사용하거나 업데이트됨:


이 접근 방식을 사용하면 별도의 쿼리를 실행하여 가져오지 않고도 INSERT/UPDATE 작업의 영향을 받은 행의 ID를 검색할 수 있습니다.

위 내용은 ON DUPLICATE KEY를 사용하여 MySQL INSERT/UPDATE 후 행 ID를 얻는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

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