JPA 구동 방식

https://www.inflearn.com/course/ORM-JPA-Basic/unit/21685?category=questionDetail&q=385382

  • Persistence 라는 클래스가 있다.
    • 설정정보를 조회하고
  • EntityManagerFactory를 만듬
    • EntityManager를 생성
EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");
  • 인자 값은 어떻게 줘야할까??
<?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/~/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>
  • persistence-unit name= " " 이곳에 들어있는 이름을 넣어줘야한다.
package hellojpa;

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

public class JpaMain {
    public static void main(String[] args) {
        EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");
        EntityManager em = emf.createEntityManager();
        /*
        * code 위치
        * */
        em.close();
        emf.close();
    }
}
  • 위의 코드는 기본적인 구조이다.
  • 이제 DB에 MEMBER라는 테이블을 만들어보자.

 

  • 핑 하기 위한 Member 클래스 또한 만들어보자
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;
    }
}
  • @Entity를 사용하여 JPA를 쓸것 이라고 알려준다.
  • PK와 매핑될 변수에 @Id를 붙여준다.
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();
        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();
    }
}
  • EntityManagerFactory는 로딩시점에 딱 하나만 만들어놔야한다.
  • 실제 디비에 저장하거나 트랜잭션 단위별로 EntityManger를 만들어야한다.

실행결과로 디비에 저장되는 것을 알 수 있다.

  • 조회
    • Member findMember = em.find(Member.class, 1L);
      • 인자로 클래스정보와 pk값을 넣어준다.
  • 삭제
    • em.remove(findMember);
    • 인자로 객체 인스턴스를 넣어준다.
  • 수정
    • findMember.setName("HelloJPA")
    • 단지 객체 내부의 이름을 변경하는 코드를 적었더니?
    • 값이 바뀌는것을 확인할 수 있었다.
    • 어떻게 자바객체에서 값만 바꿨는데 이게 가능한 걸까?
      • JPA를 통해서 Entity를 가져오면 JPA가 관리하고 commit하는 시점에 다 체크한다.
      • 바뀐점이 있다면 UPDATE 쿼리를 대신 실행해준다.

 

  • 주의
    • 엔티티 매니저 팩토리는 하나만 생성해서 애플리케이션 전체에서 공유
    • 엔티티 매니저는 쓰레드간에 공유하면안되고 사용하면 버려야 한다.
    • JPA의 모든 데이터 변경은 트랜잭션 안에서 실행

JPQL

  • JPA를 사용하면 엔티티 객체를 중심으로 개발
  • 문제는 검색 쿼리
  • 검색을 할 때도 테이블이 아닌 엔티티 객체를 대상으로 검색을 해야한다.
    • 자바 코드에서 멤버 테이블이 있구나, 멤버 객체가 있구나라고 생각을 가지고 개발해야 한다.
  • 근데, 모든 DB 데이터를 객체로 변환해서 검색하는 것은 불가능하다.
  • 애플리케이션이 필요한 데이터만 DB에서 불러오려면 결국 검색 조건이 포함된 SQL이 필요하다.
  • 그래서 JPA는 SQL을 추상화한 JPQL이라는 객체 지향 쿼리 언어를 제공한다.
  • SQL과 문법이 유사하고, SELECT, FROM, WHERE, GROUP BY, HAVING, JOIN등을 지원한다.
  • JPQL은 엔티티 객체를 대상으로 쿼리를 질의하고
  • SQL은 데이터베이스 테이블을 대상으로 쿼리를 질의한다.

 

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

객체와 테이블 매핑  (0) 2022.12.30
준영속 상태  (0) 2022.12.30
플러시  (1) 2022.12.30
영속성 컨텍스트 2  (0) 2022.12.30
영속성 컨텍스트 1  (0) 2022.12.30

+ Recent posts