inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

자바 ORM 표준 JPA 프로그래밍 - 기본편

기본 키 매핑

IDENTITY 전략

1622

김지윤

작성한 질문수 5

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이 걸린다면, 시퀀스 오브젝트가 성능의 병목이 될 가능성은 없는건가요?

JPA java

답변 1

0

김영한

안녕하세요 김지윤님^^

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

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

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

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

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

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

감사합니다.

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

29

2

inheritance startegy 선택시 고려사항

0

22

1

Entity 동등성 비교

0

21

1

실무 조언 관련 질문입니다.

0

47

1

H2데이터베이스 파일 생성

0

56

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

53

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

55

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

94

2

UnsupportedOperationException 발생

0

86

3

H2 Database 연결이 안됩니다.

0

95

2

연관관계 매핑 질문드립니다.

0

85

2

h2데이터베이스 실행오류

0

108

2

persistence.xml

0

108

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

80

1

영속성 컨텍스트

0

66

1

JPA 프록시

0

97

1

Native Query와 MyBatis

0

70

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

87

1

임베디드 타입 예시 코드 관련 질문

0

115

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

95

3

인텔리제이 패키지 커서 단축키 질문

0

108

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

145

1