inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

양방향 연관관계와 연관관계의 주인 2 - 주의점, 정리

안녕하세요. JPA로 insert if not exist 를 작성할 경우 질문 드립니다.

1043

Woo-seok Choi

작성한 질문수 17

0

JPA 에서 unique한 칼럼에 같은 이름의 row가 존재 하지 않을 경우에만 insert를 하고 그렇지 않은 경운 업데이트 하는 로직을 작성하고 싶은데요.. 객체 입장에서는 단순히 find 후에 결과가 null이면 삽입 하고, 그렇지 않으면 set 하는 로직이 될 것 같은데.. 이게 쿼리 레벨로 변환 되면 멀티쓰레드 동작 시 문제가 될 것 같은데요...

구글링을 해보면 여러 솔루션들이 나오는데 뭔가 정답 같은 딱 떨어지는 건 없는 것 같네요.. JPA 단에서 원자적으로 처리하는 방법이 있는지 궁금합니다. 아니면 최대한 비지니스 로직이나 테이블 설계에서 이런 상황을 피하는 것이 최선일까요?

java JPA

답변 1

0

김영한

안녕하세요. Woo-seok Choi님 좋은 질문입니다.

먼저 일반적인 경우에는 같은 이름의 row의 등록이 중복으로 요청되는 경우는 거의 없기 때문에 문제가 되지 않습니다. 문제가 된다고 해도 unique 제약조건으로 인해서 한쪽은 실패하게 되겠지만, 이후에 다시 시도하면 되겠지요? 이것을 사용자가 다시 시도해도 되고, 시스템이 다시 시도해도 됩니다.

그런데 정말 트래픽이 많고, 고성능으로 이 부분을 잘 처리해야 한다면, 각 데이터베이스가 제공하는 upsert 같은 네이티브 기능을 사용하는 것이 좋습니다.

감사합니다.

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

0

36

1

H2데이터베이스 파일 생성

0

45

2

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

0

47

2

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

0

45

1

JPQL 메소드와 락

0

47

1

Delivery @OneToOne

0

54

1

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

0

84

2

UnsupportedOperationException 발생

0

80

3

H2 Database 연결이 안됩니다.

0

86

2

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

0

77

2

h2데이터베이스 실행오류

0

103

2

persistence.xml

0

100

2

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

0

74

1

영속성 컨텍스트

0

59

1

JPA 프록시

0

86

1

Native Query와 MyBatis

0

60

1

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

0

81

1

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

0

110

3

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

0

89

3

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

0

100

2

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

0

133

1

양방향 연관관계 시 연관관계 주인을 설정하는 이유

0

67

1

임베디드 타입과 MappedSuperClass의 차이점이 궁금합니다.

0

95

1

데이터베이스가 초기화되는 것 같아요

1

172

2