1 분 소요


메이븐 소개

  • https://maven.apache.org/
  • 자바 라이브러리, 빌드 관리
  • 라이브러리 자동 다운로드 및 의존성 관리
  • 최근에는 Gradle을 더 많이 사용


JPA 설정하기

persistence.xml

  • JPA 설정 파일
  • /META-INF/persistence.xml 위치
  • persistence-unit name으로 이름 지정
  • javax.persistence로 시작 : JPA 표준 속성
  • hibernate로 시작: 하이버네이트 전용 속성
<!-- 생략.. -->
    <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/~/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> 


데이터베이스 방언

  • JPA는 특정 데이터베이스에 종속X
  • 각각의 데이터베이스가 제공하는 SQL 문법과 함수는 조금씩 다르다.
    • 가변 문자
      • MySQL: VARCHAR
      • Oracle: VARCHAR2
    • 문자열을 자르는 함수
      • SQL 표준: SUBSTRING()
      • Oracle: SUBSTR()
    • 페이징
      • MySQL: LIMIT
      • Oracle: ROWNUM

방언

방언이란?
SQL 표준을 지키지 않는 특정 데이터베이스만의 고유한 기능

6

  • hibernate.dialect 속성에 지정
    • H2 : org.hibernate.dialect.H2Dialect
    • MySQL : org.hibernate.dialect.MySQL5InnoDBDialect
  • 하이버네이트는 40가지 이상의 데이터베이스 방언 지원


Hello JPA 개발

JPA 구동 방식

7

객체와 테이블 생성 후 매핑

객체 생성

@Entity
public class Member {

    @Id
    private Long id;
    private String name;

    // Getter, Setter 생략...
}

테이블 생성

create table Member(
    id bigint not null,
    name varchar(255),
    primary key (id)
);

회원 등록 예제

EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");
// persistence 설정에서 name을 hello로 지정해둠

EntityManager em = emf.createEntityManager();

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

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

    em.persist(member);

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

emf.close();
  • em.persist(member);를 통해 값이 1차 캐시에 저장되고, SQL문을 생성해준다.
  • JPA의 모든 데이터 변경은 트랜잭션 안에서 실행되야 하기 때문에 tx.begin()을 통해 트랜잭션 영역을 설정했다.

[주의]

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


JPQL

소개

  • 가장 단순한 조회 방법
    • EntityManager.find()
    • 객체 그래프 탐색(a.getB().getC())
  • JPA를 사용하면 엔티티 객체를 중심으로 개발
    • em.createQuery(“select m from Member as m”, Member.class) …
  • 검색을 할 때도 테이블이 아닌 엔티티 객체를 대상으로 검색
  • 모든 DB 데이터를 객체로 변환해서 검색하는 것은 불가능
  • 애플리케이션이 필요한 데이터만 DB에서 불러오려면 결국 검색 조건이 포함된 SQL이 필요

  • JPA는 SQL을 추상화한 JPQL이라는 객체 지향 쿼리 언어 제공
  • SQL과 문법 유사.
    • SELECT, FROM, WHERE, GROUP BY, HAVING, JOIN 지원
  • JPQL은 엔티티 객체를 대상으로 쿼리
  • SQL은 데이터베이스 테이블을 대상으로 쿼리

  • 테이블이 아닌 객체를 대상으로 검색하는 객체 지향 쿼리
  • SQL을 추상화해서 특정 데이터베이스 SQL에 의존X
  • JPQL = 객체 지향 SQL


<출처 : 인프런 - 자바 ORM 표준 JPA 프로그래밍 - 기본편 (김영한)>

댓글남기기