inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

스프링 JdbcTemplate

findById와 findByName 차이점

203

gusqhr999

작성한 질문수 39

0

jdbc.Template.query 에서 인자값을 id값은 인자값으로 안넘겨주고 name은 넘겨줬는데 

조건 쿼리에서 ? 에 해당하는 값을 넘겨줘야 하는거 아닌지요? 왜 findById는 안넘겨줬나요?

또한가지는 JdbcTemplateMemberRepostory 에서 

public JdbcTempateMemberRepository(Datasource datasource)  부분에서 @Autowired선언은 생성자 하나면 안해줘도 된다고 해서 안해주셨고..

그런데 자바코드로 configuration 해주는 SpringConfig소스에서 보면 왜 그곳에서 또 DataSource를 @Autowired해주고 그 datasource 입력받은 값으로

@Bean

public MemberRepository memberRepository(){

이하부분에서 return new JdbcTeamplateRepostiry(datasource)

이부분에 datasource로 인자로 넣어줬나요? 안넣어주고 원래 JdbcTemplateMemberRepository 부분에서 이미 autowired되어있는데 말이죠..이해가 안가네요

MVC java spring-boot spring

답변 1

0

김영한

안녕하세요. gusqhr999님

jdbc.Template.query 에서 인자값을 id값은 인자값으로 안넘겨주고 name은 넘겨줬는데 

조건 쿼리에서 ? 에 해당하는 값을 넘겨줘야 하는거 아닌지요? 왜 findById는 안넘겨줬나요?

-> 9:30을 참고해주세요^^

두번째 질문하신 부분은 dataSource를 외부에서 주입할 수 있다는 것을 보여드리는 코드입니다.

지금은 SpringConfig에서 dataSource를 받아서 JdbcTemplateMemberRepository에 직접 주입하고 있습니다. 이렇게 직접 주입해도 되고, 말씀하신 것 처럼 직접 주입 받지 않고, @Autowired로 주입 받아도 됩니다. 여러가지 방법이 가능합니다.

그런데 여기서 JdbcTempalteMemberRepository를 @Bean을 사용해서 수동으로 스프링 빈으로 등록하는데, dataSource가 생성자의 필수 파라미터 이기 때문에 SpringConfig에서는 dataSource를 꼭 받아와서 넣어주어야 합니다.

감사합니다.

..

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

120

1

프로젝트 gradle-groovy ?

0

364

1

테스트코드 메서드명 한글

0

199

2