인프런 커뮤니티 질문&답변
JPA save 때 동일 컬럼이 두 번 선언되는 현상이 있습니다.
작성
·
83
·
수정됨
0
두 개의 테이블을 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 연관관계 매핑 제대로 설정하기 : 연관관계 매핑에서 발생할 수 있는 일반적인 문제와 해결책을 소개합니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.





