본문 바로가기
BackEnd/JPA

[JPA] JPA 시작하기

by 개발 Blog 2024. 7. 11.

공부 내용을 정리하고 앞으로의 학습에 이해를 돕기 위해 작성합니다.

 

프로젝트 생성

- 자바 8 이상

- maven

  ㄴ groupId : jpa-basic

  ㄴ artifactId : ex1-hello-jpa

  ㄴ version : 1.0.0

 

라이브러리 추가

<?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>jpa-basic</groupId>
    <artifactId>ex1-hello-jpa</artifactId>
    <version>1.0.0</version>

    <properties>
        <maven.compiler.source>17</maven.compiler.source>
        <maven.compiler.target>17</maven.compiler.target>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
    </properties>

    <dependencies>
        <!-- JPA 하이버네이트 -->
        <dependency>
            <groupId>org.hibernate</groupId>
            <artifactId>hibernate-core</artifactId>
            <version>6.4.2.Final</version>
        </dependency>

        <dependency>
            <groupId>javax.xml.bind</groupId>
            <artifactId>jaxb-api</artifactId>
            <version>2.3.1</version>
        </dependency>

        <!-- H2 데이터베이스 -->
        <dependency>
            <groupId>com.h2database</groupId>
            <artifactId>h2</artifactId>
            <version>2.2.224</version>
        </dependency>

        <!-- logback -->
<!--
        <dependency>
            <groupId>ch.qos.logback</groupId>
            <artifactId>logback-classic</artifactId>
            <version>1.4.14</version>
        </dependency>
-->
    </dependencies>

</project>

- 하이버 네이트 최신 버전은 https://hibernate.org/ 에서 확인할 수 있다.

- DB는 h2를 사용한다.

 

JPA 설정

/META-INF/persistence.xml에 위치

<?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="jakarta.persistence.jdbc.driver" value="org.h2.Driver"/>
            <property name="jakarta.persistence.jdbc.user" value="sa"/>
            <property name="jakarta.persistence.jdbc.password" value=""/>
            <property name="jakarta.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.use_sql_comments"  value="true"/>
            <property name="hibernate.hbm2ddl.auto" value="create" />
        </properties>
    </persistence-unit>

</persistence>

 

데이터베이스 방언

- JPA는 특정 DB에 종속되지 않는다.

- 각각 데이터 베이스가 제공하는 SQL문법과 함수는 조금씩 다르다

  •  가변 문자:
    • MySQL: VARCHAR
    • Oracle: VARCHAR2
  •  문자열 자르기 함수
    • SQL 표준: SUBSTRING()
    • Oracle: SUBSTR()
  • 페이징
    • MySQL: LIMIT
    • Oracle: ROWNUM

- 방언: SQL 표준을 따르지 않는 데이터베이스 고유의 기능.

 

 

JPA 구동 방식

- Persistence 클래스에서 설정 정보를 읽어서 팩토리 클래스를 만든다.

- 그리고 팩토리에서 필요할 때마다 매니저를 찍어내서 이용한다.

 

 

JPA 동작 확인

 

등록

package hellojpa;

import jakarta.persistence.Entity;
import jakarta.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;
    }
}

- @Entity : JPA가 관리할 객체

- @Id : 데이터베이스 PK와 매핑

 

package hellojpa;

import jakarta.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();

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

            em.persist(member);

            tx.commit();
        } catch (Exception e) {
            tx.rollback();
        } finally {
            em.close();
        }
        emf.close();
    }
}

- JPA 기능으로 HelloA가 정상적으로 등록되는 것을 볼 수 있다.

 

조회

JpaMain

- 등록했던 HelloA가 조회된다.

 

수정

JpaMain

findMember.setName 한 줄 썼는데 update가 된 이유는 뭘까?

 

- JPA는 엔티티를 조회하고 관리하며, 트랜잭션 커밋 시점에 변경 사항을 체크하여 필요시 update 쿼리를 실행하기 때문이다.

 

주의 

- 엔티티 매니저 팩토리는 하나만 생성하여 애플리케이션 전체에서 공유한다.
- 엔티티 매니저는 스레드 간에 공유하지 않고, 사용 후 버려야 한다.
- JPA의 모든 데이터 변경은 트랜잭션 안에서 실행된다.

 

JPQL

- JPA를 사용하면 엔티티 객체를 중심으로 개발한다.

- 검색 시 테이블이 아닌 엔티티 객체를 대상으로 검색한다.

- 모든 DB 데이터를 객체로 변환해 검색하는 것은 불가능하다.

- 필요한 데이터만 DB에서 불러오려면 검색 조건이 포함된 SQL이 필요하다.

- JPA는 SQL을 추상화한 객체 지향 쿼리 언어인 JPQL을 제공한다.

- JPQL은 SQL과 문법이 유사하며 SELECT, FROM, WHERE, GROUP BY, HAVING, JOIN을 지원한다.

- JPQL은 엔티티 객체를 대상으로 쿼리한다.

- JPQL은 SQL을 추상화하여 특정 데이터베이스에 의존하지 않는다.

- JPQL은 객체 지향 SQL로 정의할 수 있다.

 

 

'BackEnd > JPA' 카테고리의 다른 글

[JPA] 고급 매핑  (0) 2024.07.15
[JPA] 다양한 연관관계 매핑  (0) 2024.07.14
[JPA] 연관관계 매핑 기초  (2) 2024.07.14
[JPA] 엔티티 매핑  (0) 2024.07.12
[JPA] 영속성 관리 - 내부 동작 방식  (1) 2024.07.12