[Spring][인프런 스프링 입문] JdbcTemplate 사용법

2022. 12. 31. 12:00·공부/Spring
728x90

본 포스팅은 김영한 강사님의 인프런 강의 "스프링 입문"을 정리한 포스팅으로 강의 자료에서 사용한 자료를 사용했음을 밝힙니다.

https://www.inflearn.com/course/%EC%8A%A4%ED%94%84%EB%A7%81-%EC%9E%85%EB%AC%B8-%EC%8A%A4%ED%94%84%EB%A7%81%EB%B6%80%ED%8A%B8/dashboard

 

[무료] 스프링 입문 - 코드로 배우는 스프링 부트, 웹 MVC, DB 접근 기술 - 인프런 | 강의

스프링 입문자가 예제를 만들어가면서 스프링 웹 애플리케이션 개발 전반을 빠르게 학습할 수 있습니다., - 강의 소개 | 인프런...

www.inflearn.com

 

자바와 데이터베이스를 연결할 때 순수 Jdbc를 사용하게 되면 반복적인 코드도 존재하고 길어지게 된다.

 

JdbcTemplate을 사용하면 이러한 반복 코드를 줄일 수 있다.

 

build.gradle에 다음과 같은 설정을 해준다.

implementation 'org.springframework.boot:spring-boot-starter-jdbc'
runtimeOnly 'com.h2database:h2'

 

resources/application.properties에 다음과 같은 설정을 해준다.

spring.datasource.url=jdbc:h2:tcp://localhost/~/test
spring.datasource.driver-class-name=org.h2.Driver
spring.datasource.username=sa

https://growth-coder.tistory.com/51

 

[Spring][인프런 스프링 입문] 스프링 빈과 의존 관계

본 포스팅은 김영한 강사님의 인프런 강의 "스프링 입문"을 정리한 포스팅으로 강의 자료에서 사용한 자료를 사용했음을 밝힙니다. 웹 애플리케이션 계층 구조와 클래스 의존 관계는 아래 그림

growth-coder.tistory.com

위 포스팅에서 MemberRepository라는 interface를 만들었고 임시로 MemoryMemberRepository를 만들어 구현을 했었다.

 

이제는 직접 h2 데이터베이스에 연결하여 사용할 Repository를 만들 것이다.

 

이름은 JdbcTemplateMemberRepository로 한다.

public class JdbcTemplateMemberRepository implements MemberRepository{
    
    @Override
    public Member save(Member member) {
        return null;
    }

    @Override
    public Optional<Member> findById(long id) {
        return Optional.empty();
    }

    @Override
    public Optional<Member> findByName(String name) {
        return Optional.empty();
    }

    @Override
    public List<Member> findAll() {
        return null;
    }
}

 

레포지토리 내부에 다음과 같은 코드를 추가해서 datasource를 injection 받아야한다.

    private final JdbcTemplate jdbcTemplate;
    
    @Autowired
    public JdbcTemplateMemberRepository(DataSource dataSource) {
        this.jdbcTemplate = new JdbcTemplate(dataSource);
    }

 

rowMapper

 

결과를 받을 rowMapper를 만들어야한다.

    private RowMapper<Member> rowMapper(){

        return (rs, rowNum)->{
            Member member = new Member();
            member.setId(rs.getLong("id"));
            member.setName(rs.getString("name"));
            return member;
        };
    }

이제 이 rowMapper를 이용하면 된다.

 

<id 조회>

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

 

<name 조회>

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

 

<전체 조회>

@Override
public List<Member> findAll() {
    return jdbcTemplate.query("select * from member",rowMapper(), name);
}

 

<저장>

멤버 저장의 경우 SimpleJdbcInsert를 사용하면 쿼리를 짜지 않고 쉽게 작성할 수 있다.

@Override
public Member save(Member member) {
    SimpleJdbcInsert jdbcInsert = new SimpleJdbcInsert(jdbcTemplate);
    jdbcInsert.withTableName("member").usingGeneratedKeyColumns("id");
    Map<String, Object> parameters = new HashMap<>();
    parameters.put("name", member.getName());
    Number key = jdbcInsert.executeAndReturnKey(new MapSqlParameterSource(parameters));
    member.setId(key.longValue());
    return member;
}

 

이제 configuration에서 이 레포지토리를 사용하겠다고 알려주면 된다.

@Configuration
public class SpringConfig {
    private final DataSource datasource;

    public SpringConfig(DataSource datasource) {
        this.datasource = datasource;
    }

    @Bean
    public MemberService memberService(){
        return new MemberService(memberRepository());
    }

    @Bean
    public MemberRepository memberRepository(){
        return new JdbcTemplateMemberRepository(datasource);
    }
}

 

참고로 실행시킬 때 h2 데이터베이스와 연결을 해야한다.

728x90

'공부 > Spring' 카테고리의 다른 글

[Spring][인프런 스프링 입문] Test 코드 작성  (0) 2023.01.02
[Spring][인프런 스프링 입문] JPA 기본 사용법  (2) 2023.01.01
[Spring][Error] Consider renaming one of the beans or enabling overriding 오류  (0) 2022.12.30
[Spring][인프런 스프링 입문] 스프링 빈과 의존 관계  (0) 2022.12.29
[Spring][인프런 스프링 입문] 웹 개발 기초  (0) 2022.12.28
'공부/Spring' 카테고리의 다른 글
  • [Spring][인프런 스프링 입문] Test 코드 작성
  • [Spring][인프런 스프링 입문] JPA 기본 사용법
  • [Spring][Error] Consider renaming one of the beans or enabling overriding 오류
  • [Spring][인프런 스프링 입문] 스프링 빈과 의존 관계
웅대
웅대
알고리즘과 백엔드를 중심으로 열심히 공부 중입니다! 같이 소통하며 공부해요!
    250x250
  • 웅대
    웅대 개발 블로그
    웅대
  • 전체
    오늘
    어제
    • 분류 전체보기
      • 백준 알고리즘
        • dp
        • 문자열
        • 정렬
        • 스택
        • 브루트 포스
        • 이진 탐색
        • 정리
        • 우선순위 큐
        • 자료구조
        • 그래프
        • 기타
        • 그리디
      • 컴퓨터 언어
        • Kotlin
        • Python
        • C#
      • 공부
        • Database
        • Android Studio
        • Algorithm
        • 컴퓨터 구조론
        • Spring
        • lombok
        • AWS
        • Network
        • OS
        • Git & GitHub
        • AI
        • Computer Vision
        • 보안
        • Nginx
        • 프론트
        • express
        • GCP
        • grokking concurrency
        • DevOps
  • 블로그 메뉴

    • 홈
    • 태그
    • 방명록
  • 링크

  • 공지사항

  • 인기 글

  • 태그

    다익스트라
    parametric search
    스택
    bfs
    푸쉬 알람
    파이썬
    Vector Store
    스프링 OAuth2
    nn.RNN
    codetree
    AWS Lambda
    openvidu 배포
    ci/cd
    binary search
    RNN
    influxDB CLI
    code tree
    ChatPromptTemplate
    embedding
    Merge
  • 최근 댓글

  • 최근 글

  • hELLO· Designed By정상우.v4.10.3
웅대
[Spring][인프런 스프링 입문] JdbcTemplate 사용법
상단으로

티스토리툴바