작성자 없음
작성자 정보가 삭제된 글입니다.
작성
·
261
0
먼저 다음과 같이 부모 자식 엔티티가 있습니다.
@Entity
public class Leaf {
@Id @GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@ManyToOne(fetch = FetchType.LAZY)
@JoinColumn(name = "tree_id", referencedColumnName = "id")
private Tree tree;
}
@Entity
public class Tree {
@Id @GeneratedValue(strategy = GenerationType.IDENTITY)
private Long id;
@OneToMany(mappedBy = "tree", cascade = CascadeType.ALL, orphanRemoval = true)
private List<Leaf> leaves = new ArrayList<>();
}
Tree 엔티티는 부모이고 TreeRepository가 있는 상태입니다. Leaf 엔티티는 자식이고 Tree에 완전히 종속된다고 생각하여 Repository를 안 만들었습니다.
이 때, 비영속된 Tree에 Leaf를 추가하고 save를 시키면 영속성 전이로 인해서 Leaf들까지 전부 다 insert 되는 것은 확인하였습니다.
여기서 질문은 이미 영속화가 되어 있는 Tree를 findById() 로 찾아온 다음에 연관관계를 매핑한 새로운 Leaf를 리스트에 추가하면 insert가 되지 않았습니다. (얄팍한 지식으로 더티체킹처럼 list에 새로운 Leaf가 추가되었네? -> insert 이렇게 될 줄 알았습니다.)
여기서 Leaf를 추가하려면 LeafRepository를 따로 만들어야 할까요?? 저는 Leaf가 Tree에 완전히 종속되는 엔티티인데 Tree를 통하지 않고 Repository를 따로 만들면 데이터가 불일치할 수 있는 통로가 생긴다고 생각해서 안 만들었었습니다.
답변 2
0
앗. 문제된 부분만 따로 프로젝트를 생성하고 질문을 작성하던 와중에 문제를 해결했습니다.
테스트 코드로 검증하는데 @Transactional 애노테이션을 붙여서 쿼리가 안 나갔던 문제였습니다...;;
@Transactional 없애고 돌리니까 제가 예상한대로 쿼리가 나갔습니다...
답변 달아주셔서 감사합니다!! 덕분에 기운 얻고 해결한 것 같습니다 ㅎㅎ
0
안녕하세요. taehyun16님
어떻게 확인하셨는지 전체 코드를 보여주세요.
전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.
구글 드라이브 업로드 방법은 다음을 참고해주세요.
주의: 업로드시 링크에 있는 권한 문제 꼭 확인해주세요
추가로 다음 내용도 코멘트 부탁드립니다.
1. 실행 방법을 알려주세요.
2. 어떻게 문제를 확인할 수 있는지 자세한 설명을 남겨주세요.
감사합니다.
스스로 잘 해결하셨습니다^^