개발자 Q&A

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

2025.06.05 16:02

PDO::lastInsertId를 사용하여 최근 INSERT문 결과 ID를 얻는 방법

목록
  • UI디자이너 오래 전 2025.06.05 16:02 인기
  • 324
    1
저는 PDO::lastInsertId 함수를 사용하여 최근 INSERT문 결과 ID를 얻는 방법을 공부하고 있습니다.
하지만, PDO::lastInsertId 함수를 사용한 후, 여러 커넥션을 사용하여 INSERT문이 수행되었을 때,
마지막 INSERT문 결과 ID를 얻는 방법에 대해 궁금합니다.
예를 들어, 커넥션 A와 커넥션 B가 동시에 INSERT문이 수행되었을 때,
PDO::lastInsertId 함수를 사용하여 어떤 커넥션의 INSERT문 결과 ID를 얻을 수 있을까요?

    댓글목록

    profile_image
    나우호스팅  오래 전



    PDO::lastInsertId 함수는 현재 커넥션의 마지막 INSERT문 결과 ID를 반환합니다. 하지만, 여러 커넥션을 사용하여 INSERT문이 수행되었을 때, 마지막 INSERT문 결과 ID를 얻는 방법은 다음과 같습니다.

    1. 커넥션별로 ID를 저장하기: 각 커넥션별로 INSERT문 결과 ID를 저장하는 방법입니다. 예를 들어, 커넥션 A에서 INSERT문이 수행되었을 때, 커넥션 A의 ID를 저장하고, 커넥션 B에서 INSERT문이 수행되었을 때, 커넥션 B의 ID를 저장합니다.

    #hostingforum.kr
    php
    
    $pdo1 = new PDO('mysql:host=localhost;dbname=test', 'user', 'pass');
    
    $pdo2 = new PDO('mysql:host=localhost;dbname=test', 'user', 'pass');
    
    
    
    $pdo1->exec('INSERT INTO table (column) VALUES (value)');
    
    $pdo2->exec('INSERT INTO table (column) VALUES (value)');
    
    
    
    $lastId1 = $pdo1->lastInsertId();
    
    $lastId2 = $pdo2->lastInsertId();
    
    


    2. 트랜잭션 사용하기: 트랜잭션을 사용하면 여러 커넥션의 INSERT문이 수행된 후, 마지막 INSERT문 결과 ID를 얻을 수 있습니다. 예를 들어, 커넥션 A와 커넥션 B가 동시에 INSERT문이 수행되었을 때, 트랜잭션을 사용하여 마지막 INSERT문 결과 ID를 얻을 수 있습니다.

    #hostingforum.kr
    php
    
    $pdo1 = new PDO('mysql:host=localhost;dbname=test', 'user', 'pass');
    
    $pdo2 = new PDO('mysql:host=localhost;dbname=test', 'user', 'pass');
    
    
    
    $pdo1->beginTransaction();
    
    $pdo2->beginTransaction();
    
    
    
    $pdo1->exec('INSERT INTO table (column) VALUES (value)');
    
    $pdo2->exec('INSERT INTO table (column) VALUES (value)');
    
    
    
    $pdo1->commit();
    
    $pdo2->commit();
    
    
    
    $lastId = $pdo1->lastInsertId();
    
    


    3. ID를 저장하는 테이블 사용하기: ID를 저장하는 테이블을 사용하면 여러 커넥션의 INSERT문 결과 ID를 저장하고, 마지막 INSERT문 결과 ID를 얻을 수 있습니다. 예를 들어, 커넥션 A와 커넥션 B가 동시에 INSERT문이 수행되었을 때, ID를 저장하는 테이블을 사용하여 마지막 INSERT문 결과 ID를 얻을 수 있습니다.

    #hostingforum.kr
    php
    
    $pdo1 = new PDO('mysql:host=localhost;dbname=test', 'user', 'pass');
    
    $pdo2 = new PDO('mysql:host=localhost;dbname=test', 'user', 'pass');
    
    
    
    $pdo1->exec('INSERT INTO table (column) VALUES (value)');
    
    $pdo2->exec('INSERT INTO table (column) VALUES (value)');
    
    
    
    $pdo1->exec('INSERT INTO id_table (id) VALUES ('.$pdo1->lastInsertId().')');
    
    $pdo2->exec('INSERT INTO id_table (id) VALUES ('.$pdo2->lastInsertId().')');
    
    
    
    $pdo1->exec('SELECT MAX(id) FROM id_table');
    
    $lastId = $pdo1->fetchColumn();
    
    


    위의 방법 중 하나를 사용하여 여러 커넥션의 INSERT문 결과 ID를 얻을 수 있습니다.

    2025-06-05 16:03

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

검색

게시물 검색