개발자 Q&A

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

2025.06.07 08:46

Result::getGeneratedIds에 대한 질문

목록
  • 그래프이론도령 오래 전 2025.06.07 08:46
  • 91
    1
제가 현재 스프링 부트를 이용하여 REST API를 개발 중에 있습니다.
API 요청이 성공적으로 처리되었을 때, DB에 insert된 id를 반환하기 위해 Result::getGeneratedIds를 사용하고 있습니다.
하지만, 이 메서드가 중간에 예외가 발생하는 경우, 이전에 insert된 id를 반환하는 것 같습니다.
이러한 경우, 이전에 insert된 id를 반환하는 이유를 알고 싶습니다.
그리고 예외가 발생하는 경우, 이전에 insert된 id를 반환하지 않도록 어떻게 처리해야 하는지 알려주세요.

    댓글목록

    profile_image
    나우호스팅  오래 전



    Result::getGeneratedIds는 DB transaction 내에서 insert된 id를 반환하는 메서드입니다.

    이 메서드는 transaction이 rollback되기 전에 insert된 id를 반환하기 때문에, 중간에 예외가 발생하는 경우 이전에 insert된 id를 반환하는 것입니다.

    이러한 문제를 해결하기 위해서는, 예외가 발생하기 전에 insert된 id를 반환하도록 처리해야 합니다.

    예를 들어, 다음과 같이 try-catch 블록을 사용하여 예외를 처리할 수 있습니다.

    #hostingforum.kr
    java
    
    try {
    
        // DB에 insert 연산
    
        Result result = repository.save(entity);
    
        // transaction commit
    
        return result.getGeneratedIds();
    
    } catch (Exception e) {
    
        // transaction rollback
    
        throw new RuntimeException(e);
    
    }
    
    


    또는, DB transaction을 사용하여 insert 연산을 처리할 수 있습니다.

    #hostingforum.kr
    java
    
    @Transactional
    
    public Result save(Entity entity) {
    
        // DB에 insert 연산
    
        return repository.save(entity);
    
    }
    
    


    이 경우, insert 연산이 성공적으로 완료된 후에만 transaction이 commit되며, 예외가 발생하는 경우 transaction이 rollback됩니다.

    이러한 방법으로, 예외가 발생하는 경우 이전에 insert된 id를 반환하지 않도록 처리할 수 있습니다.

    2025-06-07 08:47

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

검색

게시물 검색