• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

IDENTITY 전략

23.01.13 17:27 작성 조회수 1.54k

0

1.IDENTITY 전략에서 em.persist() 시점에 즉시 INSERT SQL을 실행하고 DB에서 식별자를 조회하는데, 그렇다면 만약에 트랜잭션이 롤백될 경우, INSERT도 롤백된다고 한다면, ID값은 그 다음값부터 할당되는 건가요?

ex) id = 1 insert

id =2 insert, commit

id =1 rollback

next insert => id=?

 

2.DB 시퀀스 오브젝트 사용 시, 여러 서버에서 call next value for SEQ를 사용하게 될 텐데, 동시성 이슈를 막기 위해서 시퀀스 오브젝트에 lock이 걸린다면, 시퀀스 오브젝트가 성능의 병목이 될 가능성은 없는건가요?

답변 1

답변을 작성해보세요.

0

안녕하세요 김지윤님^^

2번의 경우 시퀀스 오브젝트는 매우 빠르게 번호가 나와야 하기 때문에 DB에서 일반적으로 트랜잭션과 무관하게 동작하고 락을 걸지 않습니다. 따라서 시퀀스 오브젝트가 병목이 되는 부분은 걱정하지 않아도 됩니다.

1번은 제가 직접 정답을 알려드릴 수 도 있지만, 그러면 더 많은 것을 얻어가지 못합니다.

개발자는 궁금한 부분을 직접 코드로 테스트 해볼 때 가장 많이 배울 수 있습니다.

1번의 경우 직접 코드로 간단히 테스트 해보시면 바로 결과를 이해하실 수 있을거에요.

해당 부분을 코드로 직접 테스트해보시고, 그 결과를 공유해주세요. 그러면 함께 공부하는 분들께도 큰 도움이 될거에요.

그럼 테스트 해보시고 결과도 정리해서 공유 부탁드립니다.

감사합니다.