본문 바로가기
Trouble Shooting/H2 Database

[Trouble shooting / JPA / H2] JPA hibernate.properties not found / Could not load requested class : org.h2.Driver

by drCode 2022. 11. 29.
728x90
반응형

JPA를 실습해보기 위해서,

 

Maven project를 만들고

 

pom.xml에

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>org.example</groupId>
    <artifactId>ex1-hello-jpa</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <!-- JPA 하이버네이트 -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-entitymanager</artifactId>
            <version>5.3.10.Final</version>
        </dependency>
        <!-- H2 데이터베이스 -->
        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>2.1.214</version>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <properties>
        <maven.compiler.source>11</maven.compiler.source>
        <maven.compiler.target>11</maven.compiler.target>
    </properties>
</project>

와 같이

JPA Hibernate와 H2 데이터베이스 dependency를 추가하였다.

 

그리고 

 

src/main/resource/METE-INF 디렉토리에

 

persistence.xml를 생성하여 H2 데이터베이스 정보를 넣어주었다.

<?xml version="1.0" encoding="UTF-8"?>
<persistence version="2.2"
             xmlns="http://xmlns.jcp.org/xml/ns/persistence" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
             xsi:schemaLocation="http://xmlns.jcp.org/xml/ns/persistence http://xmlns.jcp.org/xml/ns/persistence/persistence_2_2.xsd">
    <persistence-unit name="hello">
        <properties>
            <!-- 필수 속성 -->
            <property name="javax.persistence.jdbc.driver" value="org.h2.Driver"/>
            <property name="javax.persistence.jdbc.user" value="sa"/>
            <property name="javax.persistence.jdbc.password" value=""/>
            <property name="javax.persistence.jdbc.url" value="jdbc:h2:tcp://localhost/~/jpaStudy1"/>
            <property name="hibernate.dialect" value="org.hibernate.dialect.H2Dialect"/>

            <!-- 옵션 -->
            <property name="hibernate.show_sql" value="true"/>
            <property name="hibernate.format_sql" value="true"/>
            <property name="hibernate.use_sql_comments" value="true"/>
            <!--<property name="hibernate.hbm2ddl.auto" value="create" />-->
        </properties>
    </persistence-unit>
</persistence>

 

main 함수를 만들어서 EntityManagerFactory를 호출하여 정상적으로 작동하는지 확인해봤다.

 

package hellojpa;

import javax.persistence.EntityManagerFactory;
import javax.persistence.Persistence;

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

 

실행해봤더니...

 

hibernate.properties not found

위와 같이 hibernate.properties not found 에러가 떴다.

 

xml.bind 어쩌구 저쩌구 나오는 걸 보아하니

 

persistence의 정보가 bind되지 않는 것 같다.

 

이것을 해결하려면

 

pom.xml에 다음과 같은 dependency를 넣어줘야한다.

 

 

 위의 사이트에서 jaxb-api 에 해당되는 최신 버전의 Maven을 넣어주었다.

 

그러고 나서 또 돌렸는데...

 

could not load requested class : org.h2.driver

와 같이 org.h2.Driver 를 로드할 수 없다고 나온다.

 

org.h2.Driver

 

이 문제는

 

Dependency

Dependency에서 scope를 빼주면 생기지 않는다.

 

스코프를 제거한 후

 

실행하였더니

 

정상적으로 나온다.

728x90
반응형

댓글