개발자 Q&A

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

2025.05.13 13:15

SQLStatementResult::getGeneratedIds 관련 질문

목록
  • 개발하는곰돌이 2일 전 2025.05.13 13:15
  • 6
    1
저는 JPA를 사용하여 데이터를 저장할 때, SQLStatementResult::getGeneratedIds 메소드를 사용하여 생성된 ID를 가져오려고 합니다.

그런데, 이 메소드를 사용하는 방법에 대해 혼란이 있습니다.

getGeneratedIds 메소드는 SQL Statement의 결과에서 생성된 ID를 가져올 수 있는 방법을 알려주세요.

또한, 이 메소드를 사용할 때 주의할 점이 있나요?

    댓글목록

    profile_image
    나우호스팅  2일 전



    SQLStatementResult::getGeneratedIds 메소드는 JPA에서 INSERT, UPDATE, DELETE 문을 실행한 후 생성된 ID를 가져올 수 있는 방법을 제공합니다.

    이 메소드를 사용하려면, EntityManager의 executeQuery() 메소드를 사용하여 SQL Statement를 실행한 후, 결과를 SQLStatementResult 객체에 담아야 합니다.

    그 후, SQLStatementResult 객체의 getGeneratedIds() 메소드를 호출하여 생성된 ID를 가져올 수 있습니다.

    예를 들어, 다음과 같이 사용할 수 있습니다.

    #hostingforum.kr
    java
    
    EntityManager entityManager = EntityManagerFactory.createEntityManager();
    
    SQLStatementResult result = entityManager.createQuery("INSERT INTO 테이블명 (컬럼명) VALUES (:값)").setParameter("값", 값).executeQuery();
    
    List generatedIds = result.getGeneratedIds();
    
    


    이 메소드를 사용할 때 주의할 점은, getGeneratedIds() 메소드는 SQL Statement의 결과에서 생성된 ID를 가져오기 때문에, INSERT 문을 실행한 후에만 사용할 수 있습니다.

    또한, getGeneratedIds() 메소드는 여러 개의 ID를 가져올 수 있으므로, List 타입의 변수를 사용하여 결과를 받을 수 있습니다.

    또한, getGeneratedIds() 메소드는 SQL Statement의 결과에서 생성된 ID를 가져오기 때문에, UPDATE, DELETE 문을 실행한 후에는 사용할 수 없습니다.

    이 메소드를 사용할 때 주의할 점은, SQL Statement의 결과에서 생성된 ID를 가져오기 때문에, INSERT 문을 실행한 후에만 사용할 수 있습니다.

    또한, getGeneratedIds() 메소드는 여러 개의 ID를 가져올 수 있으므로, List 타입의 변수를 사용하여 결과를 받을 수 있습니다.

    예를 들어, 다음과 같이 사용할 수 있습니다.

    #hostingforum.kr
    java
    
    EntityManager entityManager = EntityManagerFactory.createEntityManager();
    
    SQLStatementResult result = entityManager.createQuery("INSERT INTO 테이블명 (컬럼명) VALUES (:값)").setParameter("값", 값).executeQuery();
    
    List generatedIds = result.getGeneratedIds();
    
    for (Long id : generatedIds) {
    
        System.out.println(id);
    
    }
    
    

    2025-05-13 13:16

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

검색

게시물 검색