inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

Entity의 Embedded타입 쿼리 질문드립니다!

351

cjswoudddn

작성한 질문수 6

1

안녕하세요 김영한선생님! 좋은 강의 잘 듣고 있습니다.

우선 강의는 완강하였고 다음 강의도 수강 예정입니다^^

그전에 몇가지만 질문 드려요!

1. 현재 Member Entity에 Embedded타입으로 Email을 넣었습니다.

@Embeddable

class Email{

    private String eHead; // '@'전까지

    private String eBody; // 첫 '.'전까지

    private String eTail;    //  나머지

}

이때 email을 통해 멤버를 찾는 쿼리를 EntityManager를 통해 생성하려고 하는데요!

이메일을 통해 멤버를 찾는 쿼리는 어떻게 생성해야 할까요?? 

단순히 

public List<Member> findByEmail(Email email){
return entityManager.createQuery("select m from Member m where m.email =: email", Member.class)
.setParameter("email", email)
.getResultList();
}

이런 방식으로는 같은 이메일임을 쿼리가 못 안다고 생각합니다 ㅠㅠ

그렇다고 email의 각 필드를 get해서 and로 처리하는 방법은 뭔가 비효율적인 것 같습니다!

더 좋은 방법이 있을까요?

2. 보통 실무에서 멤버의 썸네일과 같은 이미지 데이터는 어떻게 관리하나요??

이또한 벡엔드 서버에 넣나요? 아니면 프런트엔드 서버에 따로 관리하나요??

강의와는 좀 무관하지만 간략하게 답변해주시면 너무너무 감사하겠습니다!!

spring-boot 웹앱 spring java JPA

답변 1

1

김영한

안녕하세요. cjswoudddn님^^

혹시 해당 코드를 테스트를 해보셨나요? 테스트를 해보시면 JPA의 강력함을 더 느끼실 수 있을거에요^^

예제 코드를 넣어드립니다.

테스트 코드

@Test
void embeddedEq() {
Hello hello = new Hello();
//hello@example.com
hello.setEmail(new Email("hello", "example", "com"));
em.persist(hello);

Email emailParam = new Email("hello", "example", "com");

List<Hello> result = em.createQuery("select h from Hello h where h.email = :email", Hello.class)
.setParameter("email", emailParam)
.getResultList();

for (Hello h : result) {
System.out.println("hello result = " + h);
}
}

실행된 쿼리

select ...

from hello h

where h.e_body=? and h.e_head=? and h.e_tail=?

2. 보통 실무에서 멤버의 썸네일과 같은 이미지 데이터는 어떻게 관리하나요??

이미지는 모두 파일 서버 or AWS S3 같은 곳에 보관합니다^^

감사합니다.

OrderServiceTest 상문주문 테스트 시 update 쿼리 문의

0

27

1

sdk 설정 오류

0

68

2

오탈자 - @Transactional

0

62

1

src/test/resources 테스트 경로 문제

0

56

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

70

1

MemberRepositoryTest 실행오류

0

90

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

195

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

153

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

56

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

80

1

기본 생성자

0

67

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

107

1

멤버서비스테스트 부분에서 막힙니다.

0

174

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

124

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

129

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

121

1

24분 27초 연관관계 편의 메서드 위치

0

118

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

114

2

빌드 툴, Gradle

0

63

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

81

2

Repository에서 EntityManager 주입 방식 차이

0

97

1

롬복과 사용자 정의 setter 메서드

0

77

1

주문 목록 조회 fetch join 질문드립니다

0

91

1

dirty checking 질문드립니다.

0

86

1