작성
·
279
1
안녕하세요, 강사님
강의영상에서보시면 findById에서는 em.find를 사용하시고 findByName에서는 em.creqteQuery를 사용하셨는데요.
byId나 byName이나 하나의 컬럼 값으로 검색하는 함수인 것은 똑같은데 왜 내부에서 em을 서로 다른 방식으로 사용하는 것인지 궁금합니다.
어떤 차이가 있는 것인가요?
감사합니다.
답변 2
1
0
혹시 이게 맞을까요?
이 예제에서 name이 unique검사를 거치고 디비에 들어가긴 하지만 그렇다고해서 name이 pk는 아니기 때문에..?
pk인 id는 pk인 것만으로 유일성이 확보되니까 하나의 member를 반환하는 em.find()를 쓴 것이고,
name이 유일성을 띄는 것은 이 예제에 한해서일뿐 일반적인 경우에서 pk가 아닌 컬럼은 not unique인 경우가 많기 때문에 리스트를 반환하는 em.createQuery()를 쓴 것이다??
제 추측이 틀렸다면 올바른 이유를 가르쳐주시면 감사하겠습니다!
ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ
질문을 달고 강의를 다시 한 번 돌려들으니까 이 부분에 대해 언급을 하셨었네요..ㅎ;
왜 처음 들었을 때는 들리지가 않는지ㅠㅠ..
감사합니다!