inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

22 강 findById()메소드 질문

227

황대선

작성한 질문수 2

1

1.예

2.예

3.예

 

안녕하세요, 코드에대해 궁금한 점이 생겨 질문드립니다. 잘 부탁 드립니다.

질문 :

@Override
public Optional<Member> findById(Long id) {
    List<Member> result = jdbcTemplate.query("select * from member where id = ?", memberRowMapper());
    return result.stream().findAny();
}

select * from member where id = ? 의 결과값은 null 아니면 1개인데 List<Member> result를 사용하는 이유를 모르겠습니다. 혹시 리턴값이 Optional<Member>이기 때문인건가요??

 

아직 잘 몰라서 바보같은 질문일 수도 있지만, 잘 부탁드립니다!!

spring-boot java spring MVC

답변 1

1

OMG

안녕하세요. 황대선님, 공식 서포터즈 OMG입니다.


image

select * from member where id = ? 의 결과값은 null 아니면 1개인데

=> JdbcTemplate에서 구현한 query()는 List로 반환하도록 되어 있는데요,

말씀하신 규약은 개발하는 개발자가 정한 기준입니다. 또한 select 뿐만 아니라, delete, update 등 다른 쿼리를 사용한다면 어떨까요?

그러한 경우를 고려하여 query는 메서드 오버로딩이 되어 있습니다 ^^(리턴 타입을 확인해주세요)

image

 

 


감사합니다.

 

 

0

황대선

감사합니다^^

..

0

76

2

Unused property.....

0

100

2

project JDK is misconfigured

0

132

2

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

0

83

2

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

0

91

2

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

0

230

1

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

0

103

2

윈도우 build test오류 질문

1

102

2

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

0

100

2

테스트 실행 시 에러 질문

0

291

1

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

0

77

1

빌드 후 libs 없음

1

129

1

윈도우 gradlew.bat 에러

0

167

1

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

0

89

1

java static class와 kotlin class

0

79

1

스프링 DB연결

0

126

1

소요 시간

0

87

2

ddl.sql에 빨간 밑줄

1

102

2

welcome page 에러

0

183

3

잘 모르겠습니다.

0

164

2

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

0

156

2

index.html Welcome page

0

124

1

프로젝트 gradle-groovy ?

0

369

1

테스트코드 메서드명 한글

0

202

2