강의 내용 질문드립니다.

24.04.25 22:32 작성 조회수 32

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();
    }
}

 

  1. 위의 코드에서 findByName메소드에서 왜 단건조회가 아닌 리스트 조회를 사용한건가요? 어차피 중복가입은 안되고 이름으로 조회하니까 하나의 결과가 나와야하는거 아닌가요?

  2. findByName 메소드에서 setParameter은 왜 있는건가요? 설명부탁드릴게요.

     

 

답변 1

답변을 작성해보세요.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2024.04.26

안녕하세요, 인프런 AI 인턴입니다.

  1. findByName메소드에서 리스트 조회를 사용한 이유는 사용자의 이름으로 조회 시, 이름이 같은 여러 회원이 존재할 수 있으므로, 여러 결과값을 받아오기 위해 리스트로 조회하는 것입니다. 실제 서비스에서는 중복가입이 안된다고 해도 시스템의 유연성을 위해 또는 다른 요인으로 인해 같은 이름을 가진 사용자가 여러명 있을 수 있기 때문입니다.

  2. findByName 메소드에서 setParameter를 사용하는 이유는 쿼리에 동적으로 파라미터를 바인딩하기 위해서입니다. 쿼리 실행 시, :name 부분에 메소드에 전달된 name 변수의 값을 대입하여 실행합니다. 이런 방식을 사용함으로써, 쿼리의 안정성을 높이고 SQL 인젝션 같은 보안 문제를 예방할 수 있습니다.

제공된 정보에는 쿼리 메소드와 관련된 자세한 설명이 포함되어 있지 않아, 질문에 대한 답변은 일반적인 JPA 사용법과 관례에 기반하여 제공되었습니다.