해결된 질문
작성
·
497
답변 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 조건에 하드코딩을 할 경우, 조건이 변경 시 관리하기가 힘들겠죠?
감사합니다.
답변 감사합니다!