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

qqaa님의 프로필 이미지
qqaa

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

@ElementCollection list타입 add시 조회 쿼리 나가는 이유

작성

·

317

0


[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오) 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오) 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오) 예

[질문 내용]
https://www.inflearn.com/questions/321256
다음의 질문 글을 보고 컬렉션 타입으로 list를 사용 할 경우 데이터를 추가할때 프록시 초기화가 발생하지 않는다는것을 알았습니다.
그런데 이를 테스트 해 볼경우 저의 경우엔 조회쿼리가 나갑니다.
어떤 부분이 문제일까요?
 
Member
@Getter
@Setter
@Entity
public class Member extends BaseEntity{
@Id
@GeneratedValue(strategy = GenerationType.IDENTITY)
@Column(name = "MEMBER_ID")
private Long id;

@Column(name = "USERNAME")
private String username;

@Embedded
private Address homeAddress;

@ElementCollection
@CollectionTable(name = "FAVORITE_FOOD", joinColumns =
@JoinColumn(name = "MEMBER_ID")
)
@Column(name = "FOOD_NAME")
private Set<String> favoriteFoods = new HashSet<>();

@ElementCollection
@CollectionTable(name = "ADDRESS", joinColumns =
@JoinColumn(name = "MEMBER_ID")
)
private List<Address> addressHistory = new ArrayList<>();

}

Address
@Getter
@EqualsAndHashCode
@AllArgsConstructor
@NoArgsConstructor
@Embeddable
public class Address {
private String city;
private String zipcode;
private String street;
}

 

JpaMain

public class JpaMain {
public static void main(String[] args) {
EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");

EntityManager em = emf.createEntityManager();


EntityTransaction tx = em.getTransaction();

tx.begin();

try{
Member member = new Member();
member.setUsername("member1");
member.setHomeAddress(new Address("homeCity", "street", "10000"));

member.getFavoriteFoods().add("치킨");
member.getAddressHistory().add(new Address("old1", "street", "10000"));

em.persist(member);

em.flush();
em.clear();

System.out.println("============ START ============");
Member findMember = em.find(Member.class, member.getId());

System.out.println("====== Embeddable Set ======");
findMember.getFavoriteFoods().add("한식");

System.out.println("====== Embeddable List ======");

findMember.getAddressHistory().add(new Address("newCity1", "street", "10000"));

System.out.println("====== Commit ======");
tx.commit();
}catch(Exception e){
tx.rollback();
e.printStackTrace();
}finally {
em.close();
emf.close();
}
}

}

결과

답변 1

0

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

안녕하세요. qqaa님

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

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

https://bit.ly/3fX6ygx

 

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

 

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

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

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

감사합니다.

qqaa님의 프로필 이미지
qqaa
질문자

https://drive.google.com/file/d/1JjEGjmMQfpoac-YDSG_s5AHp_IXVbtFv/view?usp=sharing

 

2. JpaMain을 실행하면 Member에 존재하는 컬렉션 값 타입인 addressHistory 에 add로 값을 넣었을 때 list타입인데 전체 조회 쿼리가 발생합니다!

https://www.inflearn.com/questions/321256

해당 질문글을 보고 list타입일 경우엔 조회쿼리가 발생하지 않는것으로 이해했습니다!

감사합니다!

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

안녕하세요. qqqq님 공유해드린 문서를 참조해서 권한을 열어주세요.

감사합니다.

qqaa님의 프로필 이미지
qqaa
질문자

죄송합니다!! 

권한 열었습니다! 

https://drive.google.com/file/d/1JjEGjmMQfpoac-YDSG_s5AHp_IXVbtFv/view?usp=sharing 

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

안녕하세요. qqaa님 저도 확인해보니 컬렉션 프록시가 조회되어 버리네요. 하이버네이트 버전이 올라가면서 변화가 생긴 것 같은데, 저도 정확히는 모르겠습니다. 혹시 아시는 분 있으면 답변 부탁드려요.

qqaa님의 프로필 이미지
qqaa

작성한 질문수

질문하기