Continuous Challenge

3. JPA 시작하기 본문

Spring/자바 ORM 표준 JPA 프로그래밍 - 기본편

3. JPA 시작하기

응굥 2022. 3. 23. 19:49
728x90
728x90

프로젝트 생성

  1. H2 데이터베이스 설치 및 실행 (persistence.xml 작성)
  2. Maven Project 생성 (Java 8) (pom.xml 작성)

데이터베이스 방언

  • JPA는 특정 데이터베이스에 종속 X
  • 각각의 데이터베이스가 제공하는 SQL 문법과 함수는 조금씩 다름
    - 가변 문자 : MySQL은 VARCHAR, Oracle은 VARCHAR2
    - 문자열을 자르는 함수 : SQL은 표준은 SUBSTRING(), Oracle은 SUBSTR()
    - 페이징 : MySQL은 LIMIT, Oracle은 ROWNUM
  • 방언 : SQL 표준을 지키지 않는 특정 데이터베이스만의 고유한 기능
  • hibernate.dialect 속성에 지정

주의할 점

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

JPQL

  • JPA를 사용하면 엔티티 객체를 중심으로 개발
  • 모든 DB 데이터를 객체로 변환해서 검색하는 것은 불가능
    애플리케이션이 필요한 데이터만 DB에서 불러오려면 결국 검색 조건이 포함된 SQL이 필요
  • JPA는 SQL을 추상화한 JPQL이라는 객체 지향 쿼리 언어 제공 (특정 데이터베이스 SQL에 의존X)
  • SQL과 문법 유사. SELECT, FROM, WHERE, GROUP BY, HAVING, JOIN 지원
  • JPQL엔티티 객체를 대상으로 쿼리 (SQL데이터베이스 테이블을 대상으로 쿼리)
  • JPQL을 한마디로 정의하면 객체 지향 SQL

정리

  • JPA는 항상 EntityManagerFactory를 만들어야 한다. 
    - EntityManagerFactory : 데이터베이스 당 한 개씩 묶여서 돌아간다.
    - persistence.xml의 설정 정보를 읽어와서 생성한다.
  • 고객의 요청이 올 때마다 EntityManager 를 통해 작업해야 한다.
  • JPA의 모든 데이터 변경은 transaction 내에서 발생해야 한다. (EntityTransaction)
  • 자원을 모두 사용한 후에는 닫아줘야 한다. (close())

 

728x90
728x90
Comments