inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

스프링 DB 1편 - 데이터 접근 핵심 원리

정리

개인프로젝트에서 Datasource dataSource 오류

해결된 질문

366

김철준

작성한 질문수 45

0

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? 예
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? 예
3. 질문 잘하기 메뉴얼을 읽어보셨나요? 예

[질문 내용]

리포지토리인 Dto 클래스에 private final DataSource dataSource시

Could not autowire. No beans of 'DataSource' type found.

라는 오류가 뜨면서 빌드가 안 됩니다! 서비스에서 트랜잭션을 쓰지는 않지만 DataSource를 적용해보고 싶었는데 안 되네요 ㅠㅠ

 

package com.spring.dto;

import com.spring.dao.member.Member;
import lombok.RequiredArgsConstructor;
import org.springframework.stereotype.Repository;

import javax.sql.DataSource;
import java.sql.*;
import java.util.ArrayList;
import java.util.List;
import java.util.NoSuchElementException;
import java.util.Optional;


@Repository
@RequiredArgsConstructor
public class JDBCMemberDto implements MemberDto{

    private final DataSource dataSource;

    // 테이블 열
    private static final String TABLE_NAME = "USERS";
    private static final String ID_COLUMN = "ID";
    private static final String USERID_COLUMN = "USERID";
    private static final String PASSWORD_COLUMN = "PASSWORD";
    private static final String NAME_COLUMN = "NAME";

    @Override
    public Member save(Member member) {
        String query = "INSERT INTO " + TABLE_NAME + " (" + ID_COLUMN + ", " + USERID_COLUMN + ", " + PASSWORD_COLUMN + ", " + NAME_COLUMN + ") VALUES (SEQ_USER.NEXTVAL, ?, ?, ?)";

        try (Connection conn = getConnection();
             PreparedStatement pstmt = conn.prepareStatement(query)){
            pstmt.setString(1, member.getUserId());
            pstmt.setString(2, member.getPassword());
            pstmt.setString(3, member.getName());
            pstmt.executeUpdate();
        } catch (SQLException e) {
            e.printStackTrace();
        }

        return findByUserId(member.getUserId()).get();
    }

    @Override
    public Member findById(Long id) {
        Member member = new Member();
        String query = "SELECT * FROM USERS WHERE id = ?";

        try (Connection conn = getConnection();
             PreparedStatement pstmt = conn.prepareStatement(query)){
            pstmt.setLong(1, id);
            ResultSet rs = pstmt.executeQuery();
            if(rs.next()) {
                member.setId(rs.getLong(ID_COLUMN));
                member.setUserId(rs.getString(USERID_COLUMN));
                member.setPassword(rs.getString(PASSWORD_COLUMN));
                member.setName(rs.getString(NAME_COLUMN));
            } else {
                throw new NoSuchElementException("유저를 찾을 수 없습니다. memberId=" + id);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return member;
    }

    @Override
    public Optional<Member> findByUserId(String userid) {
        return findAll().stream()
                .filter(member -> member.getUserId().equals(userid))
                .findFirst();
    }

    @Override
    public List<Member> findAll() {

        List<Member> list = new ArrayList<>();

        String query = "SELECT * FROM USERS";
        try (Connection conn = getConnection();
             PreparedStatement pstmt = conn.prepareStatement(query)){
            pstmt.executeUpdate();
            ResultSet rs = pstmt.executeQuery();
            while(rs.next()) {
                Member member = new Member();
                member.setId(rs.getLong(ID_COLUMN));
                member.setUserId(rs.getString(USERID_COLUMN));
                member.setPassword(rs.getString(PASSWORD_COLUMN));
                member.setName(rs.getString(NAME_COLUMN));
                list.add(member);
            }
        } catch (SQLException e) {
            e.printStackTrace();
        }
        return list;
    }

    private Connection getConnection() throws SQLException {
        Connection connection = dataSource.getConnection();
        return connection;
    }

}

 

spring mvc spring-jdbc

답변 1

0

y2gcoder

안녕하세요. 김철준님, 공식 서포터즈 y2gcoder입니다.

스프링 부트 자동 설정을 통해 DataSource를 자동 등록해서 사용해주시려면

application.yml(application.properties)에서 spring.datasource.* 항목들을 설정해주셔야 합니다.

그렇지 않다면 @Configuration, @Bean 을 통해 자바 설정을 통해 빈으로 직접 수동 등록해주시면 아마 사용하실 수 있으실 거라 생각합니다!

 

감사합니다.

1

김철준

spring.datasource.url=
spring.datasource.username=
spring.datasource.password=

 

이거 세개는 해주었는데 또 해줘야 할게 있을까요 ㅠ

0

y2gcoder

spring.datasource.driver-class-name 도 해보시겠습니까?

0

김철준

spring.datasource.driver-class-name=oracle.jdbc.OracleDriver

오라클 db라 이렇게 해봤는데 동일합니다 ㅜ

0

김철준

아 해결했습니다. 개인 프로젝트에서는

implementation 'org.springframework.boot:spring-boot-starter-jdbc'

 

를 하지 않았네요 ㅎㅎ

spring initialiser 어떤걸 선택해야될지 모르겠어요

0

31

2

트랜잭션 템플릿이 체크예외는 커밋하는 이유가 궁금합니다.

0

50

1

jdbc 학습하다 궁금해서 질문드려요

0

82

1

정상이체와 이체중 예외발생 차이

0

68

2

이번 강의부터가 JDBC 직접 사용 맞나요?

0

87

1

순수한 서비스 계층에 대한 의문???

0

82

2

3_4test, 4test 자동 리소스 안됨

0

58

2

데이터베이스 선택 관련 질문.

0

68

2

after 메서드 사용 유무

0

56

2

데이터베이스 접근 및 DB 락

0

54

1

@SpingBootTest, @TestConfiguration

0

56

1

Read Committed 격리 수준 사용 관련 질문

0

48

1

AopCheck Test 부분의 EnhancerBySpring 확인 법??

0

66

2

커리큘럼 관련 질문

0

76

1

서비서 계층 스프링 프레임워크 사용

0

87

1

validation(toMember)의 위치

0

83

2

데이터 계층에서 서비스 로직의 datasource를 인식하는 방법

0

165

2

member 상수 질문

0

120

2

ctrl + F6 이후로 con 인식이 안 됩니다

0

153

2

DrivenManager 와 Connection 반환에 대한 질문입니다!

0

109

1

섹션5 트랜잭션 템플릿관련 질문(이기종 DB)

0

116

1

세션1 테이블 조회결과 그림은 Redo 로그에 속하나요?

0

98

1

트랜잭션이 필요하지 않은 경우 DB 대신 파일 시스템을 사용하는 것이 더 효율적인가?

0

98

1

강의 14분쯤 Exception 질문

0

114

2