작성
·
87
0
package jpabook.jpashop.domain.repository;
import jakarta.persistence.EntityManager;
import jakarta.persistence.PersistenceContext;
import jakarta.persistence.PersistenceUnit;
import jpabook.jpashop.domain.Member;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Repository;
import java.util.List;
@Repository
@RequiredArgsConstructor
public class MemberRepository {
private final EntityManager em;
public void save(Member member) {
em.persist(member);
}
public Member findOne(Long id) {
return em.find(Member.class, id);
}
public List<Member> findAll() { // 회원 목록 조회
return em.createQuery("select m from Member m", Member.class) ry
.getResultList();
}
public List<Member> findByName(String name) {
return em.createQuery("select m from Member m where m.name = :name", Member.class)
.setParameter("name", name)
.getResultList();
}
}
위의 코드에서 findByName메소드에서 왜 단건조회가 아닌 리스트 조회를 사용한건가요? 어차피 중복가입은 안되고 이름으로 조회하니까 하나의 결과가 나와야하는거 아닌가요?
findByName 메소드에서 setParameter은 왜 있는건가요? 설명부탁드릴게요.
답변 1
0
안녕하세요, 인프런 AI 인턴입니다.
findByName
메소드에서 리스트 조회를 사용한 이유는 사용자의 이름으로 조회 시, 이름이 같은 여러 회원이 존재할 수 있으므로, 여러 결과값을 받아오기 위해 리스트로 조회하는 것입니다. 실제 서비스에서는 중복가입이 안된다고 해도 시스템의 유연성을 위해 또는 다른 요인으로 인해 같은 이름을 가진 사용자가 여러명 있을 수 있기 때문입니다.
findByName
메소드에서 setParameter
를 사용하는 이유는 쿼리에 동적으로 파라미터를 바인딩하기 위해서입니다. 쿼리 실행 시, :name
부분에 메소드에 전달된 name
변수의 값을 대입하여 실행합니다. 이런 방식을 사용함으로써, 쿼리의 안정성을 높이고 SQL 인젝션 같은 보안 문제를 예방할 수 있습니다.
제공된 정보에는 쿼리 메소드와 관련된 자세한 설명이 포함되어 있지 않아, 질문에 대한 답변은 일반적인 JPA 사용법과 관례에 기반하여 제공되었습니다.