개발자 Q&A

개발하다 막혔다면? 여기서 질문하세요! 초보부터 고수까지, 함께 고민하고 해결하는 공간입니다. 누구나 자유롭게 질문하고 답변을 남겨보세요!

2025.06.16 05:50

PDO::lastInsertId 메서드 사용 방법에 대해 설명해주세요.

목록
  • 스레드마스터 오래 전 2025.06.16 05:50 인기
  • 268
    1
제가 recently SQL 쿼리문에서 INSERT INTO 문을 사용하여 데이터를 삽입했습니다.
그리고 그 후에 PDO::lastInsertId 메서드를 사용하여 마지막으로 INSERT된 ID를 얻으려고합니다.
하지만, 이 메서드를 사용할 때 어떤 조건이 있는지 궁금합니다.
예를 들어, INSERT INTO 문이 여러 개 있는 경우에는 어떤 ID를 얻을 수 있을까요?

    댓글목록

    profile_image
    나우호스팅  오래 전



    PDO::lastInsertId 메서드는 마지막으로 INSERT, UPDATE, REPLACE, DELETE, 또는 트랜잭션에 포함된 INSERT, UPDATE, REPLACE, DELETE 쿼리에서 AUTO_INCREMENT 또는 AUTO_INCREMENT에 해당하는 ID를 반환합니다.

    여러 INSERT INTO 문이 있는 경우, PDO::lastInsertId 메서드는 마지막으로 실행된 INSERT INTO 문에서 AUTO_INCREMENT ID를 반환합니다.

    예를 들어, 다음과 같은 쿼리를 실행한 경우:

    #hostingforum.kr
    php
    
    $stmt = $pdo->prepare('INSERT INTO 테이블명 (컬럼명) VALUES (?)');
    
    $stmt->execute([값]);
    
    $stmt->execute([값]);
    
    


    PDO::lastInsertId 메서드는 두 번째 INSERT INTO 문에서 AUTO_INCREMENT ID를 반환합니다.

    만약 AUTO_INCREMENT ID가 없거나, 트랜잭션 내에서 쿼리가 실행된 경우, PDO::lastInsertId 메서드는 NULL을 반환합니다.

    또한, PDO::lastInsertId 메서드는 트랜잭션 내에서 실행된 쿼리에서 AUTO_INCREMENT ID를 반환합니다.

    예를 들어, 다음과 같은 쿼리를 실행한 경우:

    #hostingforum.kr
    php
    
    $pdo->beginTransaction();
    
    $stmt = $pdo->prepare('INSERT INTO 테이블명 (컬럼명) VALUES (?)');
    
    $stmt->execute([값]);
    
    $pdo->commit();
    
    


    PDO::lastInsertId 메서드는 INSERT INTO 문에서 AUTO_INCREMENT ID를 반환합니다.

    만약 트랜잭션 내에서 쿼리가 롤백된 경우, PDO::lastInsertId 메서드는 NULL을 반환합니다.

    따라서, PDO::lastInsertId 메서드를 사용할 때는 AUTO_INCREMENT ID가 있는지 확인하고, 트랜잭션 내에서 쿼리가 실행된 경우를 고려해야 합니다.

    2025-06-16 05:51

  • 개발자 Q&A 포인트 정책
      글쓰기
      50P
      댓글
      10P
  • 전체 38,195건 / 84 페이지

검색

게시물 검색