본문 바로가기
개발하자/🍃 SpringBoot

[자바 ORM 표준 JPA 프로그래밍 - 기본편] 02. JPA 시작

by 밈밈무 2022. 9. 10.

메이븐

자바 라이브러리와 빌드를 관리하는 도구. 라이브러리를 자동 다운로드할 수 있고 의존성 관리가 가능하다.
pom.xml의 <dependencies>에 사용할 라이브러리를 지정하면 라이브러리(jar파일)를 메이븐 공식 저장소에서 내려받아 다운로드할 수 있다.
+ 최근에는 Gradle도 많이 사용한다.

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.jpa-basic</groupId>
    <artifactId>ex-1-hello-jpa</artifactId>
    <version>1.0-SNAPSHOT</version>

    <dependencies>
        <!--JPA 하이버네이트 : 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>
        </dependency>

        <dependency>
            <groupId>javax.xml.bind</groupId>
            <artifactId>jaxb-api</artifactId>
            <version>2.3.0</version>
        </dependency>
    </dependencies>
    <properties>
        <maven.compiler.source>11</maven.compiler.source>
        <maven.compiler.target>11</maven.compiler.target>
    </properties>

</project>

JPA 설정 - persistence.xml

JPA 설정파일로 /META-INF/persistence.xml에 위치한다.

persistence-unit name으로 이름을 지정한다.

  • javax.persistence : JPA 표준 속성. hibernate 말고 다른 구현체 라이브러리를 사용해도 사용할 수 있다.
  • hibernate : hibernate 전용 속성. hibernate를 사용하는 경우에만 사용할 수 있다.
<?xml version="1.0" encoding="UTF-8" ?>
<persistence xmlns="http://xmlns.jcp.org/xml/ns/persistence" version="2.2">
    <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="javaxx.persistence.jdbc.password" value=""/>
            <property name="javax.persistence.jdbc.url" value="jdbc:h2:tcp://localhost/~/test"/>
            <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.user_sql_comments" value="true"/>

        </properties>
    </persistence-unit>
</persistence>

데이터베이스 방언

JPA는 특정 데이터베이스에 종속되지 않는다. 

Dialect란 SQL표준을 지키지 않거나 특정 데이터베이스만의 고유한 기능을 JPA에서 지칭하는 말이다.

persistence.xml파일에 hibernate.dialect 속성에 지정하자.

  • H2 : org.hibernate.dialect.H2Dialect
  • Oracle 10g : org.hibernate.dialect.Oracle10gDialect
  • MySQL : org.hibernate.dialect.MySQL5Dialect

JPA 구동방식

JPA가 persistnece라는 class에서 시작해서 설정정보를 읽고 EntityManagerFactory class를 생성한 후 EntityManager를 생성한다.

객체와 테이블을 생성하고 매핑

  • @Entity : JPA가 관리할 객체라는 것을 JPA에게 알려주는 어노테이션
  • @Table : 엔티티 클래스에 매핑할 테이블 정보를 알려주는 어노테이션(생략 가능. 생략시,엔티티 이름을 테이블 이름으로 매핑)
  • @Id : 데이터베이스 PK와 매핑
  • @Column : 필드를 칼럼에 매핑

회원을 저장하려 한다면

  • 회원 등록 : em.persist(member)
  • 회원 수정 : em.persist하지 않고 자바 객체만 setter이용하여 바꿔 준다. JPA가 관리하기 때문에 transaction commit할 때 뭔가 바뀌었다면 update 쿼리를 생성하여 날리기 때문.
  • 회원 삭제 : em.remove
  • 회원 단 건 조회 : em.find(Member.class, 1L)

주의

  • EntityManagerFactory는 하나만 생성해서 애플리케이션 전체에서 공유해야 한다.(DB당 하나만 생성)
  • EntityManager는 쓰레드 간 공유하지 않고 고객 요청이 올 때 마다 사용하고 버려야 한다.
  • JPA의 모든 데이터 변경은 트랜잭션 안에서 실행된다.

JPQL

검색을 할 때도 테이블이 아닌 엔티티 객체를 대상으로 검색을 하게 되는데 이때 모든 DB데이터를 객체로 변환하여 검색하는 것은 불가능하다.

따라서 애플리케이션이 필요한 데이터만 DB에서 불러오려면 검색 조건이 포함된 SQL 이 필요하다. 

따라서 검색쿼리를 사용하는 경우 JPQL을 사용하여 객체 대상으로 쿼리가 가능하도록 한다.

JPQL을 사용하게 되면 DB에 종속되지 않고 엔티티 객체를 대상으로 쿼리를 하게 된다.