inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

JPA와 DB 설정, 동작확인

h2 database에 member 테이블이 생성되지 않아요

125

blessthy

작성한 질문수 1

0

[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)

네, jpa와 db 설정, 동작 확인 동영상 입니다.


2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)

아니요. 있는 내용인데 찾아보고 해결하지 못했습니다.


3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)


[질문 내용]
여기에 질문 내용을 남겨주세요.

테스트 코드 실행 시 member 테이블이 생성되지 않습니다. ddl 설정은 create이고, 관련 설정 확인해도 못찾아서 문의 드려요.

테스크 코드 맨 마지막에 로그를 찍어놨는데, 해당 로그가 찍히고 이 뒤에 테이블이 왜 drop될까요?

도저히 모르겠습니다...ㅎ

화면 캡처 2025-06-30 222813.png.webp화면 캡처 2025-06-30 222856.png.webp

 

https://drive.google.com/file/d/1WT3dZ7HexApj0xAYZsFJSkKVpaSmGEFM/view?usp=sharing

구글 드라이브 프로젝트 첨부 드립니다.

 

java spring 웹앱 spring-boot jpa

답변 1

0

인프런 AI 인턴

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

blessthy님, H2 데이터베이스에 Member 테이블이 생성되지 않는 문제를 겪고 계시는군요. ddl-auto: create 설정은 애플리케이션 시작 시 테이블을 생성하도록 하는데, 테스트 후 테이블이 사라진다면 설정 문제가 있을 수 있습니다.

우선, 관련 문제에 대한 다음 사항을 확인해보세요:

  1. 테스트 롤백 설정 확인:

    • @Transactional에 의해, 기본적으로 테스트가 끝나면 자동으로 롤백됩니다. 하지만 @Rollback(false) 어노테이션을 사용하여 롤백을 방지하고 있지만, 여전히 설정 파일이나 다른 곳에서 롤백이 강제로 적용되는지 확인해보세요.
  2. application.yml이나 application.properties 설정:

    • 커멘트나 설정을 다시 한 번 확인하여 ddl-auto 값이 create로 설정되어 있는지, 그리고 필요하다면 update로 변경해 테스트 후 데이터가 남아 있는지 확인해보세요.
  3. H2 콘솔 및 로그 확인:

    • 애플리케이션 실행 시, 로그에서 create table, drop table 관련 메시지와 경고 로그가 있는지 확인해 보세요.

유사한 문제에 대한 해결 사례를 소개드리겠습니다:

  1. 테이블 생성이 안됩니다:

    • 비슷한 문제를 겪었던 질문지를 참고하여 application.yml의 설정을 확인하세요. 특히, YAML의 들여쓰기가 맞지 않으면 설정이 적용되지 않는 경우가 있습니다.
  2. 코드를 실행해도 DB에 데이터가 추가되지 않습니다:

    • 각각의 설정에서 어떤 오류가 있었는지를 확인하여 프로젝트 내 설정과 비교해보세요.

이 외에 H2 콘솔에서 SQL을 실행해보거나 설정을 점검하여 추가적인 실마리를 찾는 것도 좋은 방법입니다.

저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.

1

blessthy

다음날 보니 눈에 보이네요

application.yml 설정에 오타가 있었습니다.

spring:으로 시작해야하는데 string:이라고 적어놧네요...ㅎ 후..

감사합니다.

string:
  datasource:
    url: jdbc:h2:tcp://localhost/~/jpashop
    username: sa
    password:
    driver-class-name: org.h2.Driver

  jpa:
    hibernate:
      ddl-auto: create
    properties:
      hibernate:
        show_sql: true
        format_sql: true

logging:
  level:
    org.hibernate.SQL: debug
    org.hibernate.orm.jdbc.bind: trace

OrderServiceTest 상문주문 테스트 시 update 쿼리 문의

0

27

1

sdk 설정 오류

0

67

2

오탈자 - @Transactional

0

62

1

src/test/resources 테스트 경로 문제

0

56

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

70

1

MemberRepositoryTest 실행오류

0

90

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

195

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

153

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

56

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

80

1

기본 생성자

0

67

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

107

1

멤버서비스테스트 부분에서 막힙니다.

0

174

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

124

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

129

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

121

1

24분 27초 연관관계 편의 메서드 위치

0

118

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

114

2

빌드 툴, Gradle

0

63

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

81

2

Repository에서 EntityManager 주입 방식 차이

0

97

1

롬복과 사용자 정의 setter 메서드

0

77

1

주문 목록 조회 fetch join 질문드립니다

0

91

1

dirty checking 질문드립니다.

0

86

1