inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

소개

native sql 질문 있습니다.

1127

백엔드개발자

작성한 질문수 13

2

안녕하세요 강의에서 보여주신 createNativeQuery로 쿼리를 날릴때 select 한 컬럼과 entity의 필드가 정확히 매핑되어야만 잘 날려지더라구요. 하나라도 컬럼을 빼니까 안날려지던데, 그럴거면 select * from member 로 날리는게 낫지 않나요? 아니면 createNativeQuery로 어떤 테이블의 전체 컬럼이 아닌 특정 컬럼만 얻을 수 있는 방법이 있나요?

java JPA

답변 1

2

김영한

안녕하세요. 백엔드개발자님

우선 엔티티로 조회하려면 모든 데이터가 온전히 존재해야 합니다.

반면에 원하는 데이터만 찍어서 조회하려면 DTO로 조회하면 됩니다.

관련해서 순수 JPA가 제공하는 기능으로 @SqlResultSetMapping을 사용하면 됩니다.

자세한 사용 예제는 다음 링크를 참고하시면 도움이 되실꺼에요: https://vladmihalcea.com/the-best-way-to-map-a-projection-query-to-a-dto-with-jpa-and-hibernate/

그런데 보시면 알겠지만 너무 불편합니다.

그래서 이 경우 스프링이 제공하는 JdbcTemplate을 사용하는게 더 나은 선택일 수 있습니다. 저도 정말 네이티브 쿼리를 작성해야 하면 JdbcTemplate를 종종 사용합니다.

최근에 나온 더 나은 방법은 스프링 데이터 JPA가 제공하는 프로젝션 기능을 사용하는 방법이 있습니다. 이 방법을 사용하면 네이티브 쿼리를 바로 DTO로 변환할 수 있습니다. 관련해서 자세한 내용은

스프링 데이터 JPA 강의의 섹션 7. 나머지 기능들 -> 네이티브 쿼리를 참고해주세요.

감사합니다.

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

0

41

1

H2데이터베이스 파일 생성

0

49

2

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

0

49

2

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

0

47

1

JPQL 메소드와 락

0

50

1

Delivery @OneToOne

0

56

1

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

0

87

2

UnsupportedOperationException 발생

0

82

3

H2 Database 연결이 안됩니다.

0

87

2

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

0

80

2

h2데이터베이스 실행오류

0

104

2

persistence.xml

0

102

2

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

0

77

1

영속성 컨텍스트

0

62

1

JPA 프록시

0

88

1

Native Query와 MyBatis

0

62

1

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

0

82

1

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

0

111

3

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

0

90

3

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

0

105

2

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

0

135

1

양방향 연관관계 시 연관관계 주인을 설정하는 이유

0

68

1

임베디드 타입과 MappedSuperClass의 차이점이 궁금합니다.

0

95

1

데이터베이스가 초기화되는 것 같아요

1

175

2