개발자 Q&A

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

2025.05.01 23:21

PDO::lastInsertId 사용 시 오류가 발생하는 경우

목록
  • CI/CD장인 1일 전 2025.05.01 23:21
  • 11
    1
저는 PHP에서 PDO를 사용하여 데이터베이스 연동을 하려는데, PDO::lastInsertId 함수를 사용하여 마지막으로 삽입된 ID를 가져오려고 합니다. 하지만 현재 사용하는 방법이 정상적인지 궁금합니다.

PDO::lastInsertId 함수를 사용하여 마지막으로 삽입된 ID를 가져올 수 있는지 여부를 알려주시면 감사하겠습니다.

예를 들어, insert문이 실행된 후에 lastInsertId 함수를 사용하여 ID를 가져올 수 있는 방법은 무엇인지 궁금합니다.

    댓글목록

    profile_image
    나우호스팅  1일 전



    PDO::lastInsertId 함수는 마지막으로 삽입된 ID를 반환하는 함수입니다. 하지만 이 함수를 사용하려면 INSERT 문에 AUTO_INCREMENT 또는 AUTO_INCREMENT ON NULL 키워드가 포함된 ID 열이 있어야 합니다.

    예를 들어, MySQL에서 다음 INSERT 문을 사용할 수 있습니다.

    #hostingforum.kr
    php
    
    $stmt = $pdo->prepare("INSERT INTO users (name, email) VALUES (:name, :email)");
    
    $stmt->bindParam(":name", $name);
    
    $stmt->bindParam(":email", $email);
    
    $stmt->execute();
    
    
    
    $lastId = $pdo->lastInsertId();
    
    


    이 경우, $lastId 변수에는 마지막으로 삽입된 ID가 저장됩니다. 하지만 만약 INSERT 문에 AUTO_INCREMENT 키워드가 포함되지 않은 경우, PDO::lastInsertId 함수는 NULL을 반환합니다.

    또한, PDO::lastInsertId 함수는 현재 연결된 데이터베이스에만 적용됩니다. 만약 다른 데이터베이스로 연결된 경우, 이전 데이터베이스의 마지막으로 삽입된 ID를 반환하지 않습니다.

    따라서, PDO::lastInsertId 함수를 사용하려면 INSERT 문에 AUTO_INCREMENT 키워드가 포함된 ID 열이 있어야 하며, 현재 연결된 데이터베이스에만 적용됩니다.

    2025-05-01 23:22

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

검색

게시물 검색