inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

소개

CreateNativeQuery..

290

윤승환

작성한 질문수 5

2

강의 28:50~30:00까지를 수강하고 질문 남깁니다.

 

entitymanger로부터 createNativeQuery를 받아와서 실제 SQL처럼 구문을 작성하면 알아서,, persist에 있던 것들 Flush해주고 원하는 값을 잘 가져오는데..

JDBCtemplate를 함께 사용해서.. connection받아오고,, 쿼리 작성하고 실행하고,, 이렇게 받아오는 로직과 굳이 같이 써야 하는 상황이 존재할까요...? 

동적쿼리생성이라면,, nativeQuery는 불가능한건가요...

 

이런 의문점이 생겨 질문합니다..

java JPA

답변 1

2

김영한

안녕하세요. 윤승환님

네이티브 쿼리를 사용하지만, 엔티티로 조회해야 하는 경우라면 네이티브 쿼리를 필수로 사용해야 합니다.

그렇지 않고, 단순히 데이터 조각(DTO)을 조회한다면 JDBCtemplate을 사용하셔도 됩니다.

감사합니다.

0

윤승환

엔티티로 조회해야하는 경우... -> NativeQuery를 작성해서 실행하는 구문으로 알고있는데 '필수'로 사용해야 한다는 부분이 이해하기 어렵습니다..

 

제가 생각하기로는..

1. JPQL : 엔티티 대상으로 연관관계를 매핑하여 원하는 엔티티를 찾는 Qeury

2. NativeQuery를 사용한다 : JPQL에서 해결할 수 없는 상황(ex. 엔티티관의 연관관계가 아닌 실제 테이블을 직접 join해서 원하는 데이터를 가져와야하는 상황)에서 대안으로 사용할 수 있는 query

이렇게 생각을 하고 있는데,, '엔티티로 조회해야하는 경우라면 네이티브 쿼리를 필수..'이 부분이 이해가 가지 않습니다..

 

혹시 제가 생각한 1,2 번이 잘못 된 생각일까요..?

 

또한 다음과 같이 1,2번의 생각으로는,, JDBCtemplate를 직접 사용할 필요가 없다고 생각해서 질문드렸습니다.

0

김영한

안녕하세요. 승환님

데이터를 조회할 때는 크게 2가지로 조회할 수 있습니다. 

1. 영속성 컨텍스트에서 관리되는 엔티티

2. 단순 데이터의 모음인 DTO

엔티티로 조회한다는 뜻은 영속성 컨텍스트에서 관리되는 엔티티를 조회한다는 뜻입니다.

감사합니다.

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

58

2

inheritance startegy 선택시 고려사항

0

42

1

Entity 동등성 비교

0

47

1

실무 조언 관련 질문입니다.

0

68

1

H2데이터베이스 파일 생성

0

78

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

70

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

63

1

JPQL 메소드와 락

0

63

1

Delivery @OneToOne

0

73

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

105

2

UnsupportedOperationException 발생

0

97

3

H2 Database 연결이 안됩니다.

0

103

2

연관관계 매핑 질문드립니다.

0

95

2

h2데이터베이스 실행오류

0

116

2

persistence.xml

0

121

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

90

1

영속성 컨텍스트

0

77

1

JPA 프록시

0

107

1

Native Query와 MyBatis

0

83

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

97

1

임베디드 타입 예시 코드 관련 질문

0

126

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

103

3

인텔리제이 패키지 커서 단축키 질문

0

113

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

156

1