인프런 커뮤니티 질문&답변

오채은님의 프로필 이미지

작성한 질문수

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

순수 JDBC

h2 DB 연결시 Table not found

작성

·

184

0

[질문 내용]
섹션 6 JDBC 연결 과정

h2 DB 연결 과정에서 h2 환경 구축, memebr 테이블 생성까지 에러없이 잘 됐구요. h2 콘솔에서도 테이블 확인 해 보면 잘 보입니다.

근데 이제 강사님이 알려주신 방법대로 DB를 MemoryMemberRepository -> JdbcMemberRepository로 변경하는 과정에서 JdbcMemberRepository 클래스 파일과 SpringConfig 파일 코드 복붙 해왔는데 실행시키면 회원가입과 회원 목록 조회시 자꾸 member라는 테이블을 못찾는 오류가 뜹니다...ㅠ 왜 그런걸까요ㅠㅠ

스크린샷 2024-08-04 오전 12.57.19.png스크린샷 2024-08-04 오전 12.54.24.png

 

답변 1

0

안녕하세요, 인프런 AI 인턴입니다.

오채은님께서 겪고 계신 ‘Table “MEMBER” not found 오류’는 스프링 부트 애플리케이션과 H2 데이터베이스 간 연동 과정에서 발생한 것으로 보입니다. 이러한 종류의 오류는 보통 H2 데이터베이스 설정 또는 연동 과정에서의 설정 누락 또는 오류로 발생하곤 합니다. 오채은님의 경우, 강의를 따라 하시다가 발생한 문제로 보이며, 특히 JdbcMemberRepository 클래스로의 변경 과정 중에 발생한 것 같습니다.

오류 해결을 위해 몇 가지 확인 사항과 해결 방안을 제안해보고자 합니다:

  1. application.properties 설정 확인: 데이터베이스 URL이 올바르게 설정되었는지 다시 한번 확인해 주세요. H2 데이터베이스를 사용할 때 접속 URL이 올바르게 지정되어 있지 않으면, 예상과 다른 데이터베이스나 테이블에 접근하게 될 수 있습니다.

  2. H2 데이터베이스가 실행 중인지 확인: H2 데이터베이스를 통해 애플리케이션 실행 시 데이터베이스가 실제로 실행되고 있는지 확인해주세요. 데이터베이스가 실행되지 않았다면, 테이블을 찾을 수 없는 오류가 발생할 수 있습니다.

  3. 테이블 생성 SQL 실행 여부: H2 데이터베이스에 접속하여 MEMBER 테이블이 실제로 존재하는지 다시 한번 확인해 보시길 바랍니다. 만약 테이블이 존재하지 않는다면, MEMBER 테이블을 생성하는 SQL 쿼리를 실행해야 할 수 있습니다.

  4. 데이터 소스 설정의 영향을 받는지 확인: 간혹 application.properties 또는 SpringConfig 클래스 오류가 아닌, 프로젝트의 다른 설정이나 의존성 문제로 발생할 수 있습니다. 이 경우, 강의 자료나 공식 문서를 다시 한번 꼼꼼히 확인해 보시길 권장합니다.

유사한 문제 해결에 대한 경험이 공유된 다른 게시물도 참조하시면 도움이 될 것 같습니다:

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.

현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏

추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

오채은님의 프로필 이미지
오채은
질문자

첨부해주신 링크 들어가서 쿼리문 다시 실행 후 잘 돌아가네요!

감사합니다 :)