프로젝트 생성
- H2 데이터베이스 설치 및 실행 (persistence.xml 작성)
- 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
'Spring > 자바 ORM 표준 JPA 프로그래밍 - 기본편' 카테고리의 다른 글
4. 엔티티 매핑 - 필드와 컬럼 매핑 (1) | 2022.03.25 |
---|---|
4. 엔티티 매핑 - 객체와 테이블 매핑 (1) | 2022.03.25 |
3. 영속성 관리 - 내부 동작 방식 (1) | 2022.03.24 |
2. JPA 소개 (1) | 2022.03.23 |
1. 강좌 소개 (0) | 2022.03.22 |