집 >데이터 베이스 >MySQL 튜토리얼 >ON DUPLICATE KEY를 사용하여 MySQL INSERT/UPDATE 후 행 ID를 얻는 방법은 무엇입니까?
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 중국어 웹사이트의 기타 관련 기사를 참조하세요!