JPA (Java Persistence API)
자바 진영의 ORM(Object Relational Mapping) 기술 표준
* ORM 객체 관계 매핑 - 객체는 객체대로 설계 - 관계형 데이터베이스는 관계형 데이터베이스대로 설계 - ORM 프레임워크가 중간에서 매핑 - 대중적인 언어에는 대부분 ORM 기술이 존재 |
JPA의 장점
SQL 중심적인 개발에서 객체 중심으로 개발할 수 있기 때문에 SQL을 작성하지 않아도 된다.
개발 생산성, 유지보수, 개발 속도가 확연히 상승한다.
생산성
CRUD
저장 : jpa.persist(member)
조회 : Member member = jpa.find(memberId)
수정 : member.setName("변경할 이름")
삭제 : jpa.remove(member)
유지보수
기존에는 필드 변경 시 모든 SQL을 수정해야 했지만, JPA를 사용하면 필드만 추가하면 된다.
SQL은 JPA가 처리해준다.
JPA와 패러다임의 불일치를 해결
1. 상속
Album album = jpa.find(Album.class, albumId);
개발자가 CRUD 코드를 작성하면
SELECT I.*, A.*
FROM ITEM I
JOIN ALBUM A ON I.ITEM_ID = A.ITEM_ID
JPA가 알아서 SQL로 처리해준다.
2. JPA와 연관관계, 객체 그래프 탐색
member.setTeam(team);
jpa.persist(member);
연관관계 저장
Member member = jpa.find(Member.class, memberId);
Team team = member.getTeam();
객체 그래프 탐색
신뢰할 수 있는 엔티티, 계층
class MemberService {
...
public void process() {
Member member = memberDAO.find(memberId);
member.getTeam(); //자유로운 객체 그래프 탐색
member.getOrder().getDelivery();
}
}
JPA의 성능 최적화 기능
1. 1차 캐시와 동일성(identity) 보장
같은 트랜잭션 안에서는 같은 엔티티를 반환한다. - 약간의 조회 성능 향상
DB Isolation Level이 Read Commit이어도 애플리케이션에서 Repeatable Read 보장
String memberId = "100";
Member m1 = jpa.find(Member.class, memberId); //SQL
Member m2 = jpa.find(Member.class, memberId); //캐시
println(m1 == m2) //true
동일한 트랜잭션에서 조회한 엔티티는 같음을 보장하기 때문에 SQL문이 1번만 실행된다.
2. 트랜잭션을 지원하는 쓰기 지연(transactional write-behind)
transaction.begin(); // [트랜잭션] 시작
em.persist(memberA);
em.persist(memberB);
em.persist(memberC);
//여기까지 INSERT SQL을 데이터베이스에 보내지 않는다.
//커밋하는 순간 데이터베이스에 INSERT SQL을 모아서 보낸다.
transaction.commit(); // [트랜잭션] 커밋
INSERT
트랜잭션을 commit할 때까지 insert SQL을 모아두었다가
JDBC BATCH SQL 기능을 사용해서 한번에 SQL을 전송한다.
transaction.begin(); // [트랜잭션] 시작
changeMember(memberA);
deleteMember(memberB);
비즈니스_로직_수행(); //비즈니스 로직 수행 동안 DB 로우 락이 걸리지 않는다.
//커밋하는 순간 데이터베이스에 UPDATE, DELETE SQL을 보낸다.
transaction.commit(); // [트랜잭션] 커밋
UPDATE
UPDATE, DELETE로 인한 로우락 시간 최소화
트랜잭션 commit 시 update, delete SQL 실행하고 바로 commit한다.
3. 지연 로딩(Lazy Loading)
지연 로딩 : 객체가 실제 사용될 때 로딩
즉시 로딩 : JOIN SQL로 한번에 연관된 객체까지 미리 조회
'DB' 카테고리의 다른 글
[PGSQL] 락조회 / 락KILL (1) | 2023.11.26 |
---|---|
[Oracle] sequence 생성 / sequence 번호 수정 (0) | 2023.11.26 |
[Oracle] sequence 번호 수정 (0) | 2023.10.25 |
[JPA] JPA란 (2) - JPA 프로젝트 생성, JPQL (0) | 2023.10.25 |
[JPA] JPA, 스프링 데이터 JPA (0) | 2023.10.25 |