인프런 영문 브랜드 로고
인프런 영문 브랜드 로고

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

작성자 없음

작성자 정보가 삭제된 글입니다.

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

간단한 주문 조회 V4: JPA에서 DTO로 바로 조회

질문 있습니다!

작성

·

573

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭
@Entity
public class Member {
    @Id @GeneratedValue
    private Long id;

    private String name;


    @OneToMany(fetch = FetchType.LAZY)
    @JoinColumn(name = "TEAM_ID")
    private List<Team> teamList;

    @OneToMany(fetch = FetchType.LAZY)
    @JoinColumn(name = "ADDR_ID", referencedColumnName = "ADDR_ID")
    private List<Addr> addrInfo;
}

위와 같은 Entity가 있습니다. 두개의 Entity와 연관관계가 맵핑되어있는 Eentity인데요

 List<Member> memberList = memberDao.findAllById(id);
 List<String> teamList = teamList.stream().map(Member::getTeamList).flatMap(List::stream).map(Team::getTeamName).collect(Collectors.toList());

 

위의 코드를 실행하면

간혹가다 아래의 에러가 나옵니다..

Message
JpaSystemException: Found shared references to a collection: com.co.test.model.Member.addrInfo; nested exception is org.hibernate.HibernateException: Found shared references to a collection: com.co.test.model.addrInfo
Date
2021-11-04 14:08:20
StackTrace
org.springframework.orm.jpa.JpaSystemException: Found shared references to a collection: com.co.test.model.Member.addrInfo; nested exception is org.hibernate.HibernateException: Found shared references to a collection: com.co.test.model.Member.addrInfo

위의 에러를 찾아보니 참조하고 있는 객체를 복사해서 사용할려고 하면 나온다고 하는데... 복사할려고 시도조차 한적이 없는 코드인데 왜 가끔 나오는걸까요?? 일주일동안 찾아도 이유를 모르겠더라구요...

답변 1

0

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. 허지노님

전체 프로젝트를 압축해서 구글 드라이브로 공유해서 링크를 남겨주세요.

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

https://bit.ly/3fX6ygx

 

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

 

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

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

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

감사합니다.

안녕하세요 영한님. 

답변 감사합니다.

회사 프로젝트라서 소스는 못올려 드리지만 

현재 문제가 스케쥴러에서 제가 조회한 Entity의 특정값을 삭제하는 부분인데 

그 Entity를 조회 할때 에러가 나는 부분입니다.

심지어 AddrInfo라는 객체를 참조는 하진 않지만 LAZY로 지연로딩이기도 하고

코드상 AddrInfo를 호출 하지도 않는데 에러가 나서 

혹시 Entity에서 두개의 연관되어있는 Entity가 있으면 조회 해오거나 할때 주의 할점이 있나 했습니다.

제가 질문드린 이유는 제 로컬에선 아무리해도 저런 에러가 구현이 안되고 

운영에 반영만 하면 해당 에러가 나더라구요...

제가 소스를 못올려드려 죄송합니다.. 어차피 로컬에선 에러가 안나더라구요..

그래도 해결해주시려고 하셔서 감사합니다!!

김영한님의 프로필 이미지
김영한
지식공유자

네 해당 부분은 코드가 있어야 할 것 같아요.

이후에라도 유사한 코드를 만들어서 상황을 재현할 수 있다면 도움을 드리겠습니다.

감사합니다.

작성자 없음

작성자 정보가 삭제된 글입니다.

질문하기