inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

한 엔티티에 같은 JoinColumn name이 있을경우 어떻게 처리하는지 궁금합니다.

88

작성자 없음

작성한 질문수 0

0

@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "user_id")
private User createUser;

@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "user_id")
private User lastModifyUser;

DB 한 테이블에 글 등록 유저 정보와 마지막 수정 유저 정보를 넣도록 설계했는데

아래와 같이 안되면 이럴때는 보통 설계를 어떻게 하나요??

Caused by: org.hibernate.MappingException: Column 'user_id' is duplicated in mapping for entity 'study.factory.domain.Order' (use '@Column(insertable=false, updatable=false)' when mapping multiple properties to the same column)

java spring 웹앱 spring-boot jpa

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 AI 인턴입니다.

질문해주신 내용은 JPA 매핑 시 동일한 테이블 컬럼에 여러 엔티티 필드를 매핑하고자 할 때 발생하는 문제입니다. 한 테이블의 컬럼을 여러 필드에 매핑하려면 Hibernate에서는 @Column(insertable=false, updatable=false)를 사용해 충돌을 피할 수 있습니다.

그런데, 지금 예제에서는 동일한 컬럼 user_idcreateUserlastModifyUser에 동일하게 매핑하고 있어 발생한 문제입니다.

이와 같은 경우, 보통 다음과 같은 방법을 사용하여 문제를 해결합니다:

해결 방안

  1. 별도의 컬럼 사용: createUserlastModifyUser 필드 각각을 데이터베이스의 별도 컬럼에 매핑하는 방식입니다. 예: create_user_id, last_modify_user_id로 컬럼 이름을 각각 변경합니다.

  2. 중복 매핑 방지: 이미 언급하신 방법처럼 (insertable=false, updatable=false) 옵션을 사용하여 같은 컬럼에 다른 필드를 매핑하도록 설정할 수 있지만, 이는 보통 데이터를 저장하거나 수정할 때 데이터를 잃을 수 있으므로 데이터베이스 설계 측면에서 최선의 방법은 아닙니다.

  3. 테이블 구조 변경 고려: 사용자가 구분되는 경우, 테이블 구조를 재설계하여 명확하게 사용자 정보가 식별될 수 있도록 하는 방법도 있습니다. 이를 통해 데이터 무결성과 확장성을 확보할 수 있습니다.

해당 문제와 관련된 추가적인 설명은 다음 게시물에서도 확인하실 수 있습니다:
- @JoinColumn 의 name, referencedColumnName 에 대해 질문 드립니다. - 인프런 | 질문 & 답변 (inflearn.com)

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

OrderServiceTest 상문주문 테스트 시 update 쿼리 문의

0

27

1

sdk 설정 오류

0

68

2

오탈자 - @Transactional

0

62

1

src/test/resources 테스트 경로 문제

0

56

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

70

1

MemberRepositoryTest 실행오류

0

90

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

195

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

153

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

56

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

80

1

기본 생성자

0

67

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

107

1

멤버서비스테스트 부분에서 막힙니다.

0

174

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

124

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

129

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

121

1

24분 27초 연관관계 편의 메서드 위치

0

118

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

114

2

빌드 툴, Gradle

0

63

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

81

2

Repository에서 EntityManager 주입 방식 차이

0

97

1

롬복과 사용자 정의 setter 메서드

0

77

1

주문 목록 조회 fetch join 질문드립니다

0

91

1

dirty checking 질문드립니다.

0

86

1