파라미터 바인딩
강의에서는 파라미터 바인딩을 이름 기반으로 해라 정도만 나와있습니다.
그런데 , 이 파라미터 바인딩이 무엇이고, 이걸 왜 쓰는지 이런 설명이 없다보니 이해가 되지 않습니다.
파라미터 조인으로 뭘 하는 건가요?ㅠㅠ
List<Member> resultList =
em.createQuery("select m from Member m inner join m.team t " +
"where t.name = :teamname", Member.class)
.getResultList();
답변 1
6
안녕하세요. 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 조건에 하드코딩을 할 경우, 조건이 변경 시 관리하기가 힘들겠죠?
감사합니다.
벌크연산에서 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





