inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술

JPA

findById와 findByName의 차이?

336

akakakakak

작성한 질문수 83

1

안녕하세요, 강사님

강의영상에서보시면 findById에서는 em.find를 사용하시고 findByName에서는 em.creqteQuery를 사용하셨는데요.

byId나 byName이나 하나의 컬럼 값으로 검색하는 함수인 것은 똑같은데 왜 내부에서 em을 서로 다른 방식으로 사용하는 것인지 궁금합니다.

어떤 차이가 있는 것인가요?

감사합니다.

java spring spring-boot MVC

답변 2

1

김영한

ㅎㅎ 네^^

0

akakakakak

혹시 이게 맞을까요?

이 예제에서 name이 unique검사를 거치고 디비에 들어가긴 하지만 그렇다고해서 name이 pk는 아니기 때문에..?

pk인 id는 pk인 것만으로 유일성이 확보되니까 하나의 member를 반환하는 em.find()를 쓴 것이고,

name이 유일성을 띄는 것은 이 예제에 한해서일뿐 일반적인 경우에서 pk가 아닌 컬럼은 not unique인 경우가 많기 때문에 리스트를 반환하는 em.createQuery()를 쓴 것이다??

제 추측이 틀렸다면 올바른 이유를 가르쳐주시면 감사하겠습니다!

ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ

질문을 달고 강의를 다시 한 번 돌려들으니까 이 부분에 대해 언급을 하셨었네요..ㅎ;

왜 처음 들었을 때는 들리지가 않는지ㅠㅠ..

감사합니다!

..

0

74

2

Unused property.....

0

98

2

project JDK is misconfigured

0

130

2

외부 API의 ID 타입(String/UUID)과 내부 도메인의 ID 타입(Long)이 불일치할 때의 설계 정석

0

82

2

단위/통합 테스트 버전충돌 문제

0

91

2

❗️springboot 4.0.2 버전 aspectj dependency 설정❗️

0

228

1

왜 컨트롤러는 변한게 없는데 새로 만든 html 파일이 뜨나요?

0

101

2

윈도우 build test오류 질문

1

102

2

테스트 관련 공부에 대한 조언을 얻고 싶습니다

0

98

2

테스트 실행 시 에러 질문

0

289

1

name을 통한 비교와 객체를 통한 비교

0

77

1

빌드 후 libs 없음

1

128

1

윈도우 gradlew.bat 에러

0

167

1

@PostMapping("/members/new")가 동작하지 않습니다

0

88

1

java static class와 kotlin class

0

77

1

스프링 DB연결

0

126

1

소요 시간

0

85

2

ddl.sql에 빨간 밑줄

1

101

2

welcome page 에러

0

180

3

잘 모르겠습니다.

0

163

2

fail을 똑같이 쳤는데 오류가 발생해요

0

156

2

index.html Welcome page

0

121

1

프로젝트 gradle-groovy ?

0

364

1

테스트코드 메서드명 한글

0

199

2