강의 내용 질문드립니다.
142
작성한 질문수 31
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 사용법과 관례에 기반하여 제공되었습니다.
rabbitmq에 configservice 연결에 대해 질문있습니다.
0
12
1
빈 스코프 개념의 중요성
0
17
1
트랙잭션 격리수준 선택에 대해서 질문
0
23
1
안녕하세요 치킨 디도스 이벤트 보고 흉내내보려 들어왔습니다..
0
26
2
실무 내용 문의드려요
0
28
2
join에대해 질문드립니다.
0
23
1
코드 질문
0
33
2
To-Do App
0
27
1
twitterdb 연결이 안돼요
1
30
2
SingletonService가 JVM이 뜰 때 생성되는게 맞나요?
0
66
2
임포트 오류
0
39
2
답을언제쯤받아볼수있나요
0
58
2
형 책 어떻게 받아?
1
61
1
@JsonIgnore 이후 Internal Server Error가 발생하지 않습니다.
0
34
2
mvc 패턴 - 적용 강의에서 회원가입할 때 redirect가 아닌 forward인 이유가 궁금합니다.
0
31
1
프로젝트가 없어요..
0
67
2
JpaCursorItemReader의 정렬 조건 부재의 영향
1
47
2
changeTeam 메서드 질문
0
35
1
"컴파일 시점에 없는 값을 어떻게 참조할 것인가?" 섹션
1
54
2
테스트 관련 질문!
0
58
2
handleBindException 의 기대의도가 방향이 맞는지 궁금합니다.
0
43
2
SpringBoot 4.0.6 버전에서 PackageLogTracePostProcessor exception
0
91
3
인텔리제이 오류
0
56
1
안녕하세요 질문있습니다.
0
49
2





