inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

JPA save 때 동일 컬럼이 두 번 선언되는 현상이 있습니다.

97

gao9512

작성한 질문수 1

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

 

 

java spring spring-boot jpa

답변 1

0

인프런 AI 인턴

안녕하세요, 인프런 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 옵션을 활성화하면 로깅됩니다.

참고 게시물

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

강의 관련 외 질문입니다.

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