• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

연관관계를 갖고 있는 entity에서 persist 호출시 연관관계의 entity 에도 insert 쿼리문이 실행 됩니다.

22.11.25 16:37 작성 조회수 277

0

안녕하세요

사용자정의 리포지토리 구현 챕터를 듣고 실제 구현 후 이슈가 생겨서 문의를 드립니다!

엔티티

  • 회사정보

CompInfo_entity.png

  • 회사코드정보

CompCodeInfo_entity.png

연관관계

회사정보 1 : N 회사코드정보

사용자정의 리포지토리 구성

  • 회사코드 리포지토리

CompCodeRepository.png

  • 회사코드 사용자정의 리포지토리

    → CompCodeInfo persist 호출하는 createCompCode method

CompCodeRepositoryCustom.png

서비스 구성

  • 단순히 createCompCode 호출

CompCodeService.png

  • dto > entity 변환 static method

    → CompInfo entity 내에 id 세팅 static method 호출 후 CompCodeInfo의 compInfo 세팅

entity_변환.png

서비스 실행 결과

insert문실행.png

궁긍한점

JpaRepository에서 지원하는 save method로 CompCodeInfo 생성시 CompInfo에 대해 insert 문이 실행되지 않습니다.

근데 위와 같은 구성으로 persist를 직접 호출시 CompInfo에 대해 insert문이 실행됩니다.

save method도 결국 EntityManager의 persist를 호출하는건데 왜 이런 차이가 있는지 궁금합니다.

 

 

답변 1

답변을 작성해보세요.

1

안녕하세요. hameron님

적어주신 코드만으로는 정확한 확인이 어렵습니다.

실제 동작하는 예제를 샘플 프로젝트를 만들고 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

(동작하는 케이스, 아닌 케이스 모두 만들어주세요)

구글 드라이브 업로드 방법은 다음을 참고해주세요.

https://bit.ly/3fX6ygx

주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요

추가로 다음 내용도 코멘트 부탁드립니다.

1. 실행 방법을 알려주세요.

2. 어떻게 문제를 확인할 수 있는지 자세한 설명을 남겨주세요.

감사합니다.

hameron님의 프로필

hameron

질문자

2022.12.01

죄송합니다. 답변 확인이 늦었습니다

제가 질문에 CompCodeInfo entity에서 복합키 사용 중이라 @IdClass를 사용했는데 해당 class는 공유하지 않았었네요

질문 당시 Id Class

image

변경 된 Entity 및 Id Class

image

image

entity에서 복합키안에 외래키 존재시 @EmbeddedId를 사용해야 하는데 @IdClass를 사용했더니 비정상적으로 작동 했던 것 같습니다.

현재는 질문 처럼 CompInfo에 insert쿼리문이 날아가지 않고 CompCodeInfo에 대해서만 insert가 정상적으로 진행 됩니다.

저는 쓰임새에 맞지 않게 사용했기 때문에 JPA가 비정상적으로 작동 했다고 생각했는데요

혹시 명확한 다른 이유가 있는지도 궁금합니다.

아래 테스트 코드도 공유합니다

https://drive.google.com/file/d/1j_LFKqgvIHQNuGluqLqxsIfk4FwrXJ5F/view?usp=sharing

  1. STS로 작성했고 springboot, java, maven, jdk17, h2 db 사용했습니다.

  2. CodeApplicationTest.java 에서 테스트 가능합니다.

안녕하세요. hameron님

코드를 확인해보았는데요. 저도 정확한 이유를 잘 모르겠습니다. 혹시 아시는 분이 있으면 답변 부탁드려요.

감사합니다.