개발자 Q&A

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

2025.06.27 16:13

SqlStatementResult::getGeneratedIds에 대한 질문

목록
  • 정렬연구가 15시간 전 2025.06.27 16:13 새글
  • 4
    1
저는 현재 Hibernate를 사용 중인데, SqlStatementResult::getGeneratedIds 메소드에 대한 이해가 부족합니다.

SqlStatementResult::getGeneratedIds 메소드는 어떤 기능을 하는 것 인가요?
그리고 이 메소드를 사용하는 경우는 언제인지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  15시간 전



    SqlStatementResult::getGeneratedIds 메소드는 Hibernate가 INSERT, UPDATE, DELETE 등 DML 연산을 수행한 후 생성된 ID를 반환하는 메소드입니다.

    이 메소드는 Hibernate가 생성한 ID를 얻기 위해 사용됩니다. 예를 들어, INSERT 연산을 수행한 후 생성된 ID를 얻기 위해 사용할 수 있습니다.

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

    #hostingforum.kr
    java
    
    Session session = sessionFactory.getCurrentSession();
    
    Transaction transaction = session.beginTransaction();
    
    
    
    // INSERT 연산을 수행한 후 생성된 ID를 얻기 위해 사용
    
    Long generatedId = (Long) session.getSqlStatementResult().getGeneratedIds()[0];
    
    


    이 메소드는 DML 연산을 수행한 후 생성된 ID를 반환하므로, DML 연산이 수행된 후에 호출해야 합니다.

    또한, 이 메소드는 여러 개의 ID를 반환할 수 있으므로, 배열로 반환됩니다.

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

    #hostingforum.kr
    java
    
    Session session = sessionFactory.getCurrentSession();
    
    Transaction transaction = session.beginTransaction();
    
    
    
    // INSERT 연산을 수행한 후 생성된 ID를 얻기 위해 사용
    
    Long[] generatedIds = (Long[]) session.getSqlStatementResult().getGeneratedIds();
    
    


    이 메소드를 사용하는 경우는 다음과 같습니다.

    - INSERT 연산을 수행한 후 생성된 ID를 얻기 위해 사용
    - UPDATE 연산을 수행한 후 생성된 ID를 얻기 위해 사용
    - DELETE 연산을 수행한 후 생성된 ID를 얻기 위해 사용

    이 메소드는 Hibernate가 생성한 ID를 얻기 위해 사용되므로, Hibernate를 사용하는 경우에 사용됩니다.

    2025-06-27 16:14

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

검색

게시물 검색