inflearn logo
강의

Course

Instructor

Java ORM Standard JPA Programming - Basics

Hello JPA - Application Development

UnsupportedOperationException 발생

80

lgh8079

35 asked

0

package hellojpa;

import javax.persistence.Entity;
import javax.persistence.Id;

@Entity
public class Member {

    @Id
    private Long id;
    private String name;

    public Long getId() {
        return id;
    }

    public void setId(Long id) {
        this.id = id;
    }

    public String getName() {
        return name;
    }

    public void setName(String name) {
        this.name = name;
    }
}
package hellojpa;

import javax.persistence.EntityManager;
import javax.persistence.EntityManagerFactory;
import javax.persistence.EntityTransaction;
import javax.persistence.Persistence;

public class JpaMain {

    public static void main(String[] args) {
        EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");

        EntityManager em = emf.createEntityManager();

        EntityTransaction tx = em.getTransaction();
        tx.begin();

        Member member = new Member();
        member.setId(1L);
        member.setName("HelloA");

        em.persist(member);

        tx.commit();

        em.close();

        emf.close();

    }
}
image.png

C:\Users\User\.jdks\temurin-21.0.9\bin\java.exe "-javaagent:C:\Program Files\JetBrains\IntelliJ IDEA 2025.2.2\lib\idea_rt.jar=65054" -Dfile.encoding=UTF-8 -Dsun.stdout.encoding=UTF-8 -Dsun.stderr.encoding=UTF-8 -classpath C:\study\ex1-hello-jpa\ex1-hello-jpa\target\classes;C:\Users\User\.m2\repository\javax\xml\bind\jaxb-api\2.3.0\jaxb-api-2.3.0.jar;C:\Users\User\.m2\repository\org\hibernate\hibernate-entitymanager\5.3.10.Final\hibernate-entitymanager-5.3.10.Final.jar;C:\Users\User\.m2\repository\org\jboss\logging\jboss-logging\3.3.2.Final\jboss-logging-3.3.2.Final.jar;C:\Users\User\.m2\repository\org\hibernate\hibernate-core\5.3.10.Final\hibernate-core-5.3.10.Final.jar;C:\Users\User\.m2\repository\org\javassist\javassist\3.23.2-GA\javassist-3.23.2-GA.jar;C:\Users\User\.m2\repository\antlr\antlr\2.7.7\antlr-2.7.7.jar;C:\Users\User\.m2\repository\org\jboss\jandex\2.0.5.Final\jandex-2.0.5.Final.jar;C:\Users\User\.m2\repository\com\fasterxml\classmate\1.3.4\classmate-1.3.4.jar;C:\Users\User\.m2\repository\javax\activation\javax.activation-api\1.2.0\javax.activation-api-1.2.0.jar;C:\Users\User\.m2\repository\org\dom4j\dom4j\2.1.1\dom4j-2.1.1.jar;C:\Users\User\.m2\repository\org\hibernate\common\hibernate-commons-annotations\5.0.4.Final\hibernate-commons-annotations-5.0.4.Final.jar;C:\Users\User\.m2\repository\javax\persistence\javax.persistence-api\2.2\javax.persistence-api-2.2.jar;C:\Users\User\.m2\repository\net\bytebuddy\byte-buddy\1.9.5\byte-buddy-1.9.5.jar;C:\Users\User\.m2\repository\org\jboss\spec\javax\transaction\jboss-transaction-api_1.2_spec\1.1.1.Final\jboss-transaction-api_1.2_spec-1.1.1.Final.jar;C:\Users\User\.m2\repository\com\h2database\h2\1.4.199\h2-1.4.199.jar hellojpa.JpaMain

1월 13, 2026 3:42:37 오후 org.hibernate.jpa.internal.util.LogHelper logPersistenceUnitInformation

INFO: HHH000204: Processing PersistenceUnitInfo [

name: hello

...]

1월 13, 2026 3:42:37 오후 org.hibernate.Version logVersion

INFO: HHH000412: Hibernate Core {5.3.10.Final}

1월 13, 2026 3:42:37 오후 org.hibernate.cfg.Environment <clinit>

INFO: HHH000206: hibernate.properties not found

1월 13, 2026 3:42:37 오후 org.hibernate.annotations.common.reflection.java.JavaReflectionManager <clinit>

INFO: HCANN000001: Hibernate Commons Annotations {5.0.4.Final}

1월 13, 2026 3:42:38 오후 org.hibernate.engine.jdbc.connections.internal.ConnectionProviderInitiator initiateService

WARN: HHH000181: No appropriate connection provider encountered, assuming application will be supplying connections

1월 13, 2026 3:42:38 오후 org.hibernate.engine.jdbc.env.internal.JdbcEnvironmentInitiator initiateService

WARN: HHH000342: Could not obtain connection to query metadata : The application must supply JDBC connections

1월 13, 2026 3:42:38 오후 org.hibernate.dialect.Dialect <init>

INFO: HHH000400: Using dialect: org.hibernate.dialect.H2Dialect

1월 13, 2026 3:42:38 오후 org.hibernate.engine.jdbc.env.internal.LobCreatorBuilderImpl makeLobCreatorBuilder

INFO: HHH000422: Disabling contextual LOB creation as connection was null

Exception in thread "main" java.lang.UnsupportedOperationException: The application must supply JDBC connections

at org.hibernate.engine.jdbc.connections.internal.UserSuppliedConnectionProviderImpl.getConnection(UserSuppliedConnectionProviderImpl.java:44)

at org.hibernate.internal.NonContextualJdbcConnectionAccess.obtainConnection(NonContextualJdbcConnectionAccess.java:35)

at org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl.acquireConnectionIfNeeded(LogicalConnectionManagedImpl.java:106)

at org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl.getPhysicalConnection(LogicalConnectionManagedImpl.java:136)

at org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl.getConnectionForTransactionManagement(LogicalConnectionManagedImpl.java:254)

at org.hibernate.resource.jdbc.internal.LogicalConnectionManagedImpl.begin(LogicalConnectionManagedImpl.java:262)

at org.hibernate.resource.transaction.backend.jdbc.internal.JdbcResourceLocalTransactionCoordinatorImpl$TransactionDriverControlImpl.begin(JdbcResourceLocalTransactionCoordinatorImpl.java:236)

at org.hibernate.engine.transaction.internal.TransactionImpl.begin(TransactionImpl.java:86)

at hellojpa.JpaMain.main(JpaMain.java:16)

Process finished with exit code 1

이거 에러 발생한 이유가 뭘까요? 강의 러닝타임은 11분대입니다.

java jpa

Answer 3

0

yh

안녕하세요. lgh8079님

H2 데이터베이스가 정상적으로 실행되지 않은 것으로 보입니다.

H2 데이터베이스를 먼저 실행해주세요 🙂

감사합니다.

0

communityai8509

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

lgh8079님께서 겪고 계신 UnsupportedOperationException 에러는 JDBC 연결 공급과 관련된 설정 문제로 보입니다. Hibernate를 사용할 때 JDBC 연결을 명시적으로 공급하지 않으면 발생하는 전형적인 오류입니다. 이 문제를 해결하기 위해 persistence.xml 파일을 확인하여 데이터베이스 연결이 올바르게 설정되었는지 확인해보시기 바랍니다.

아래에 몇 가지 확인해야 할 사항을 정리해드리겠습니다:

  1. persistence.xml 파일 확인

    • 데이터베이스 연결 정보를 지정하는 property 태그들이 잘 설정되어 있는지 확인하세요.
    • 예를 들어, javax.persistence.jdbc.driver, javax.persistence.jdbc.url, javax.persistence.jdbc.user, javax.persistence.jdbc.password와 같은 정보가 정확히 입력되어 있어야 합니다.
  2. 데이터베이스 상태 확인

    • H2 데이터베이스가 실행 중인지 확인하고, jdbc:h2:tcp://localhost/~/test URL로 설정되어 있는지 확인하세요.
  3. JDBC 드라이버 의존성

    • maven이나 gradle에서 JDBC 드라이버에 대한 의존성이 제대로 추가되어 있는지 확인하세요.
  4. Hibernate 버전 문제

    • 간혹 버전 간 호환성 문제가 있을 수 있습니다. 사용하는 Hibernate와 JPA의 버전이 호환되는지 확인해 보세요.

아래 링크에서는 유사한 문제에 대한 해결 방법을 제공합니다:
- Hibernate: UnsupportedOperationException 오류 해결하기 - 특히, 포트와 관련된 설정이 잘 되어 있는지 다시 한번 확인해 보시기를 권장합니다.

문제의 원인을 파악하고 해결하려면 persistence.xml 파일에 잘못된 부분이 없는지, 특히 데이터베이스 연결 정보가 올바르게 입력되었는지 확인해야 합니다. 문제가 지속된다면 위의 내용을 중심으로 더욱 자세히 확인해 보시고, 추가적인 정보가 필요하다면 이어서 질문해 주세요. 곧 지식공유자께서도 추가적인 도움을 드릴 수 있을 것입니다.

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

-1

David

안녕하세요. lgh8079님, 공식 서포터즈 David입니다.

데이터베이스 연결 설정이 정상적으로 작성되었을까요?

감사합니다.

실무 조언 관련 질문입니다.

0

36

1

H2데이터베이스 파일 생성

0

45

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

47

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

45

1

JPQL 메소드와 락

0

47

1

Delivery @OneToOne

0

54

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

84

2

H2 Database 연결이 안됩니다.

0

86

2

연관관계 매핑 질문드립니다.

0

77

2

h2데이터베이스 실행오류

0

103

2

persistence.xml

0

100

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

74

1

영속성 컨텍스트

0

59

1

JPA 프록시

0

86

1

Native Query와 MyBatis

0

60

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

81

1

임베디드 타입 예시 코드 관련 질문

0

110

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

89

3

인텔리제이 패키지 커서 단축키 질문

0

100

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

133

1

양방향 연관관계 시 연관관계 주인을 설정하는 이유

0

67

1

임베디드 타입과 MappedSuperClass의 차이점이 궁금합니다.

0

95

1

데이터베이스가 초기화되는 것 같아요

1

172

2

getReference()하면 영속성 컨텍스트에 속하게 되나요?

0

74

1