Notice
Recent Posts
Recent Comments
Link
250x250
«   2025/02   »
1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28
Tags
more
Archives
Today
Total
관리 메뉴

거인의 코딩일지

[JPA] JPA(Java Persistenence API) 란????? 본문

코딩/JAVA

[JPA] JPA(Java Persistenence API) 란?????

코딩거인 2023. 8. 22. 15:58
728x90
JPA == Java Persistenence API, 자바진영의 ORM 기술 표준!
ORM(Object Relational Mapping) 이란??
    - 객체 관계 매핑
    - 객체는 객체대로, 관계형 데이터 베이스는 관계형 데이터 베이스 대로 설계한다
    - ORM 프레임워크가 중간에서 매핑해준다.
    - 대중적인 언어에는 대부분 ORM 기술이 존재한다.

 

JPA 의 사용 이유
  1. SQL 중심 적인 개발에서 객체 중심으로 개발
  2. 생산성
  3. 유지보수
  4. 패러다임의 불일치 해결
  5. 성능
  6. 데이터 접근 추상화와 벤더 독립성
  7. 표준
2. 생산성 (JPA 와 CRUD)
• 저장: jpa.persist(member)
• 조회: Member member = jpa.find(memberId)
• 수정: member.setName(“변경할 이름”)
• 삭제: jpa.remove(member
3. 유지보수 
• 기존: 필드 변경시 모든 SQL 수정
• JPA: 필드만 추가하면 됨, SQL은 JPA가 처리
ex) 아래 사진 참고

 

 

4. JPA와 패러다임의 불일치 해결
• JPA와 상속
• JPA와 연관관계
• JPA와 객체 그래프 탐색
• JPA와 비교하기

JPA와 상속

- 저장 : (개발자) jpa.persist(album);
  : (나머지는 JPA 가 처리)  INSERT INTO ITEM... , INSERT INTO ALBUM....,

- 조회 : (개발자) Album album = jpa.find(Album.class, albumId);
  : (나머지는 JPA 가 처리) 
SELECT I.*, A.*
    FROM ITEM I 
    JOIN ALBUM A ON I.ITEM_ID = A.ITEM.ID

JPA와 연관관계, 객체 그래프 탐색

연관관계 저장
member.setTeam(team);
jpa.persist(member);

객체그래프 탐색
Member member = jpa.find(Member.class, memberId);
Team team = member.getTeam();

JPA와 비교

String memberId = "100";
Member member1 = jpa.find(Member.class, memberId);
Member member2 = jpa.find(Member.class, memberId);
member1 == member2; //같다.

-- 동일한 트랜잭션 안에서 조회한 엔티티는 같음을 보장한다.

 

5. JPA의 성능 최적화 기능
• 1차 캐시와 동일성(identity) 보장
• 트랜잭션을 지원하는 쓰기 지연(transactional write-behind)
• 지연 로딩(Lazy Loading)

1차 캐시와 동일성 보장

1. 같은 트랜잭션 안에서는 같은 엔티티를 반환 - 약간의 조회 성능 향상
2. 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번만 실행 한다.
// 같은 트랜잭션 안에서만 성립!! 다른 트랜잭션에서는 성립하지 않는다!!!

트랜잭션을 지원하는 쓰기 지연

1. 트랜잭션을 커밋할 때까지 INSERT SQL을 모음
2. JDBC BATCH SQL 기능을 사용해서 한번에 SQL 전송

transaction.begin(); // [트랜잭션] 시작
em.persist(memberA);
em.persist(memberB);
em.persist(memberC);
//여기까지 INSERT SQL을 데이터베이스에 보내지 않는다.
//커밋하는 순간 데이터베이스에 INSERT SQL을 모아서 보낸다.
transaction.commit(); // [트랜잭션] 커밋

 

지연 로딩과 즉시 로딩

• 지연 로딩: 객체가 실제 사용될 때 로딩
• 즉시 로딩: JOIN SQL로 한번에 연관된 객체까지 미리 조회

 

참고 : https://www.inflearn.com/course/ORM-JPA-Basic (김영한 님의 기본 JPA)

 

자바 ORM 표준 JPA 프로그래밍 - 기본편 - 인프런 | 강의

초급자를 위해 준비한 [웹 개발, 백엔드] 강의입니다. JPA를 처음 접하거나, 실무에서 JPA를 사용하지만 기본 이론이 부족하신 분들이 JPA의 기본 이론을 탄탄하게 학습해서 초보자도 실무에서 자

www.inflearn.com

728x90