inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

조인

파라미터 바인딩

해결된 질문

563

sy k

작성한 질문수 40

4

강의에서는 파라미터 바인딩을 이름 기반으로 해라 정도만 나와있습니다.

그런데 , 이 파라미터 바인딩이 무엇이고, 이걸 왜 쓰는지 이런 설명이 없다보니 이해가 되지 않습니다.

 

파라미터 조인으로 뭘 하는 건가요?ㅠㅠ

List<Member> resultList =

em.createQuery("select m from Member m inner join m.team t " +

"where t.name = :teamname", Member.class)

.getResultList();

java JPA

답변 1

6

OMG

안녕하세요. sy k님, 공식 서포터즈 OMG입니다.
이 부분은 어렵게 생각하시지 않아도 됩니다 ^^

간단한 예시를 들게요.

SELECT *

FROM MEMBER

WHERE NAME = '홍길동';

위 쿼리는 MEMBER 테이블에서 이름이 "홍길동"을 찾는 쿼리입니다.

근데, JPA에서는 조금 특별한 방식을 지원합니다.

SELECT *

FROM MEMBER

WHERE NAME = :memName;

위 쿼리는 NAME이 "memName"

을 찾는 쿼리가 아닙니다. memName으로 지정되어 있는 값이랑 연결되어 연결된 값으로 바뀌는데, 이게 강의에서 말하는 파라미터 바인딩 입니다.

em.createQuery("select m from Member m where m.name = :memName", Member.class)

.setParameter("memName","홍길동")

.getResultList();

위 JPQL이 memName이 치환되어 아래와 같이 되는 것입니다.

SELECT *

FROM MEMBER

WHERE NAME = '홍길동';

파라미터 바인딩을 하지 않고, '홍길동'을 쿼리 where 조건에 하드코딩을 할 경우, 조건이 변경 시 관리하기가 힘들겠죠?


감사합니다.

0

sy k

답변 감사합니다!

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

0

57

2

inheritance startegy 선택시 고려사항

0

41

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

71

1

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

0

104

2

UnsupportedOperationException 발생

0

97

3

H2 Database 연결이 안됩니다.

0

102

2

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

0

95

2

h2데이터베이스 실행오류

0

116

2

persistence.xml

0

121

2

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

0

89

1

영속성 컨텍스트

0

75

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

154

1