강의

멘토링

커뮤니티

인프런 커뮤니티 질문&답변

gao9512님의 프로필 이미지
gao9512

작성한 질문수

실전! 스프링 부트와 JPA 활용2 - API 개발과 성능 최적화

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값)

 

 

 

아래는 소스 내용의 일부입니다.

 

image.pngimage.png

 

image.png

 

image.png

 

 

답변 1

0

안녕하세요, 인프런 AI 인턴입니다. gao9512님께서 겪고 있는 문제는 JPA의 연관관계 매핑에서 흔히 발생할 수 있는 문제입니다. 제공해주신 정보로는 정확한 코드 맥락을 알 수 없지만, 몇 가지 가능성 있는 원인과 해결 방법을 설명드리겠습니다.

문제 원인

  1. 중복된 컬럼 매핑: 연관관계 매핑에서 @OneToOne이나 @ManyToOne을 사용할 때, JPA가 연관된 엔티티의 식별자를 제대로 매핑하지 못하면 쿼리에 동일한 컬럼이 두 번 삽입되는 문제가 발생할 수 있습니다. 특히, @JoinColumn을 사용할 때 컬럼 이름을 명시적으로 정의하지 않으면 기본 전략에 의해 중복되는 일이 생길 수 있습니다.

  2. 양방향 연관관계 매핑 시 중복 선언: 만약 AccountAuthority 양쪽에서 같은 컬럼을 식별자로 사용하고 있다면, 해당 컬럼이 서로 다른 이름으로 설정되지 않았을 수 있습니다.

해결 방법

  • 컬럼 명시적 설정: @JoinColumn을 사용할 때 명시적으로 name 속성을 설정하여 중복되는 컬럼명이 아닌 새로운 이름을 지정합니다. 예를 들어:

    @OneToOne
    @JoinColumn(name = "login_id_fk")
    private Authority authority;
    
  • 식별자 전략 확인: AccountAuthority의 식별자 생성 전략을 확인하고, 식별자의 값을 직접 할당하거나 자동 생성하는 전략을 적절히 선택합니다.

  • 양방향 연관관계에서 컬럼명 확인: 양방향 연관관계일 경우 각 엔티티에 설정된 컬럼명이 중복되지 않는지 확인합니다.

  • SQL 로그 확인: 실행된 실제 SQL 쿼리를 확인하여 어떤 부분에서 중복이 발생하는지 파악해보세요. application 설정 파일에서 hibernate.show_sql 옵션을 활성화하면 로깅됩니다.

참고 게시물

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

gao9512님의 프로필 이미지
gao9512

작성한 질문수

질문하기