• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

테스트 코드 연결하는데 데베에 문제가 있다고 하네요

24.07.01 19:48 작성 조회수 49

0

Caused by: org.hibernate.HibernateException: Unable to determine Dialect without JDBC metadata (please set 'jakarta.persistence.jdbc.url' for common cases or 'hibernate.dialect' when a custom Dialect implementation must be provided)

at org.hibernate.engine.jdbc.dialect.internal.DialectFactoryImpl.determineDialect(DialectFactoryImpl.java:191) ~[hibernate-core-6.4.4.Final.jar:6.4.4.Final]

at org.hibernate.engine.jdbc.dialect.internal.DialectFactoryImpl.buildDialect(DialectFactoryImpl.java:87) ~[hibernate-core-6.4.4.Final.jar:6.4.4.Final]

at org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator.getJdbcEnvironmentWithDefaults(JdbcEnvironmentInitiator.java:143) ~[hibernate-core-6.4.4.Final.jar:6.4.4.Final]

이런식의 오류가 났는데 데베설정이 잘못돼서 그런건가요 코듣상의 문제는 없는거 같습니다.

답변 2

·

답변을 작성해보세요.

0

OMG님의 프로필

OMG

2024.07.01

안녕하세요. 오키님, 공식 서포터즈 OMG입니다.

h2를 실행중인 상태에서 확인한게 맞을까요?

application.yml의 설정의 띄어쓰기와 오타가 있는지 확인해주세요 😀

해결이 안될 경우 댓글 남겨주세요.

감사합니다.

0

인프런 AI 인턴님의 프로필

인프런 AI 인턴

2024.07.01

안녕하세요, 인프런 AI 인턴입니다. 오키님, 질문하신 내용과 관련하여 에러 메시지 ‘Unable to determine Dialect without JDBC metadata (please set ‘jakarta.persistence.jdbc.url’ for common cases or ‘hibernate.dialect’ when a custom Dialect implementation must be provided)‘는 올바른 JDBC URL 설정이 되지 않았거나 Hibernate Dialect가 설정되지 않아 발생하는 문제입니다. Hibernate Dialect는 Hibernate가 데이터베이스와 통신할 때 사용하는 SQL 변형을 정의합니다. 이는 데이터베이스마다 SQL 문법이 약간씩 다르기 때문에 필요한 설정입니다.

이와 관련하여, 제가 검토한 질문 중 다음 자료가 도움이 될 것 같습니다:

  • “H2 데이터베이스 연결 에러 해결 방법”에서는 비슷한 문제로 H2 데이터베이스와의 연결 문제로 인해 발생하는 오류를 해결하기 위한 조치가 설명되어 있습니다. 사용하고 계신 데이터베이스와 설정을 다시 확인하시길 권장합니다.

  • 그리고 “MemberRepositoryTest 실행이 되지 않습니다.”에서는 javax.persistence.jdbc.url 설정을 추가하라는 구체적인 해결책이 제시되었습니다. 해당 설정을 application.properties나 application.yml 파일에 추가하면 문제가 해결될 수 있습니다.

각 데이터베이스에 맞는 Dialect 설정이 필요합니다. 예를 들어, H2 데이터베이스의 경우 spring.jpa.properties.hibernate.dialect=org.hibernate.dialect.H2Dialect와 같은 방식으로 설정할 수 있습니다. 연결하고자 하는 데이터베이스에 맞는 Dialect를 설정해보시기 바랍니다.

추가적으로 application.properties나 application.yml 파일에 올바른 데이터베이스 연결 정보가 포함되어 있는지 확인해보시기 바랍니다. 예를 들어, URL, 사용자 이름(username), 비밀번호(password) 등이 올바르게 설정되어 있어야 합니다.

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

채널톡 아이콘