JPA save 때 동일 컬럼이 두 번 선언되는 현상이 있습니다.
97
작성한 질문수 1
두 개의 테이블을 OneToOne으로 연관관계를 설정하여 JPA 로 account와 authority테이블을 한 번에 save하는 로직을 강의 내용을 응용하여 개발하고 있습니다.
save를 통해 저장하려고 하면 insert 구문에 LOGIN_ID가 두 번 지정되어 쿼리가 날아가는 현상이 있는데 어느 부분이 잘못된 것인지 도움 부탁드립니다..
(쿼리문 예시
insert into LOGIN_ACCOUNT (LOGIN_ID, ~~~, login_id)
select SCOPE_IDENTITY() AS GENERATED_KEYS', ~~~, form에서 입력받은 실제 id값)
아래는 소스 내용의 일부입니다.




답변 1
0
안녕하세요, 인프런 AI 인턴입니다. gao9512님께서 겪고 있는 문제는 JPA의 연관관계 매핑에서 흔히 발생할 수 있는 문제입니다. 제공해주신 정보로는 정확한 코드 맥락을 알 수 없지만, 몇 가지 가능성 있는 원인과 해결 방법을 설명드리겠습니다.
문제 원인
중복된 컬럼 매핑: 연관관계 매핑에서
@OneToOne이나@ManyToOne을 사용할 때, JPA가 연관된 엔티티의 식별자를 제대로 매핑하지 못하면 쿼리에 동일한 컬럼이 두 번 삽입되는 문제가 발생할 수 있습니다. 특히,@JoinColumn을 사용할 때 컬럼 이름을 명시적으로 정의하지 않으면 기본 전략에 의해 중복되는 일이 생길 수 있습니다.양방향 연관관계 매핑 시 중복 선언: 만약
Account와Authority양쪽에서 같은 컬럼을 식별자로 사용하고 있다면, 해당 컬럼이 서로 다른 이름으로 설정되지 않았을 수 있습니다.
해결 방법
컬럼 명시적 설정:
@JoinColumn을 사용할 때 명시적으로name속성을 설정하여 중복되는 컬럼명이 아닌 새로운 이름을 지정합니다. 예를 들어:@OneToOne @JoinColumn(name = "login_id_fk") private Authority authority;식별자 전략 확인:
Account와Authority의 식별자 생성 전략을 확인하고, 식별자의 값을 직접 할당하거나 자동 생성하는 전략을 적절히 선택합니다.양방향 연관관계에서 컬럼명 확인: 양방향 연관관계일 경우 각 엔티티에 설정된 컬럼명이 중복되지 않는지 확인합니다.
SQL 로그 확인: 실행된 실제 SQL 쿼리를 확인하여 어떤 부분에서 중복이 발생하는지 파악해보세요. application 설정 파일에서
hibernate.show_sql옵션을 활성화하면 로깅됩니다.
참고 게시물
- JPA 연관관계 매핑 제대로 설정하기 : 연관관계 매핑에서 발생할 수 있는 일반적인 문제와 해결책을 소개합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
강의 관련 외 질문입니다.
0
75
2
SpringBoot4 + Hibernate7 모듈 등록 방법 공유
1
95
1
BeanCreationException
0
94
3
Update 후 UpdateMemberResponse 매핑할 때
0
53
1
트랜잭션을 사용 안 할 때 커넥션은 언제 가져오나요?
0
102
2
페이징 + 검색조건 관련해서 질문드립니다.
0
74
1
Query Dsl Q파일 질문입니다.
0
86
1
루트 쿼리라는것은
0
62
1
메서드를 분리하는 기준
0
70
1
findAllWithMemberDelivery 메서드 질문드립니다.
0
115
3
연관관계 매핑을 안 쓸 경우, 사용해야 하는 전략
0
90
2
fetch join과 영속화와 OSIV의 관계
0
90
2
Distinct 사용 전 결과에 대한 의문
0
117
2
레포지토리 계층에서의 트랜잭션에 대한 의문
0
61
1
영속성 컨텍스트 생명주기의 신기한 부분이 있습니다.
0
79
2
dto 필드 속 엔티티 여부
0
61
1
뷰템플릿 사용 시
0
82
2
Result 클래스 관련 질문
0
56
1
@PostConstruct 프록시 관련 질문드립니다
0
87
1
DTO 대신 Form 사용은 안되나요?
0
140
1
OSIV ON 상태일 때
0
98
1
fetch join VS fetch join 페이징 궁금증
0
189
2
양방향 연관관계 알아보는 법?
0
108
1
16강 17강 간단 정리 이게 맞을까요 ?
0
167
2





