반응형
영속성 컨텍스트란?
- "엔티티를 영구 저장하는 환경"
- JPA를 이해하는데 가장 중요한 용어
- 눈에 보이지 않는 논리적인 개념
- 엔티티 매니저를 통해서 영속석 컨텍스트에 접근
EntityManager.persist(entity);
DB에 저장하는 것이 아니라 엔티티를 영속성 컨텍스트에 저장하는 것
Q. 그러면 언제 DB에 저장되는가?
더보기
A. transaction.commit(); 하는 시점에 쓰기 지연 SQL 저장소에 있던 데이터들이 flush가 되고 DB에 쿼리가 날라간다.
엔티티의 생명주기
- 비영속 (new/transient)
영속성 컨텍스트와 전혀 관계가 없는 새로운 상태
//객체를 생성한 상태(비영속)
Member member = new Member();
member.setId("member1");
member.setUsername("회원1");
- 영속 (managed)
영속성 컨텍스트에 관리되는 상태
//객체를 생성한 상태(비영속)
Member member = new Member();
member.setId("member1");
member.setUsername("회원1");
EntityManager em = emf.createEntityManager();
em.getTransaction().begin();
//객체를 저장한 상태(영속)
em.persist(member);
- 준영속 (detached)
영속성 컨텍스트에 저장되었다가 분리된 상태
//회원 엔티티를 영속성 컨텍스트에서 분리, 준영속 상태
em.detach(member);
- 삭제 (removed)
삭제된 상태
//객체를 삭제한 상태(삭제)
em.remove(member);
영속성 컨텍스트의 이점
- 1차 캐시 - 1차 캐시는 한 트랜잭션 안에서만 효과가 있음
- 1. find("member") - member를 1차 캐시에서 찾음
- 2. 1차 캐시에 없으면 DB 조회
- 3. DB에서 조회한 값을 1차 캐시에 저장
- 4. 반환
- 영속 엔티티의 동일성(identity) 보장
- 같은 트랜잭션 안에서 같은 데이터를 찾을 경우 동일성을 비교하면 true 반환
- 엔티티를 등록 할 때 트랜잭션을 지원하는 쓰기 지연 (transactional write-behind)
EntityManager em = emf.createEntityManager();
EntityTransaction transaction = em.getTransaction();
//엔티티 매니저는 데이터 변경시 트랜잭션을 시작해야 한다.
transaction.begin(); // [트랜잭션] 시작
em.persist(memberA);
em.persist(memberB);
//여기까지 INSERT SQL을 데이터베이스에 보내지 않는다.
//커밋하는 순간 데이터베이스에 INSERT SQL을 보낸다.
transaction.commit(); // [트랜잭션] 커밋
- 변경 감지(Dirty Checking)
// [트랜잭션] 시작
// 영속 엔티티 조회
Member memberA = em.find(Member.class, "memberA");
// 영속 엔티티 데이터 수정
memberA.setName("Kim");
// em.persist(memberA); 불필요
transaction.commit(); // [트랜잭션] 커밋
데이터 수정과 트랜잭셕 커밋 사이에 업데이트를 해 줄 필요가 없다.
- 지연 로딩(Lazy Loading) ⭐️
참조 - 자바 ORM 표준 JPA 프로그래밍
반응형
'웹개발 > Spring' 카테고리의 다른 글
[JPA] 양방향 연관관계 (0) | 2020.01.19 |
---|---|
[JPA] 엔티티 매핑 ⭐️ @Entity, @Table, @Column, @Id (0) | 2020.01.17 |
[JPA] 플러시란? Flush (0) | 2020.01.17 |
[JPA] 준영속 엔티티란? 변경 감지와 병합(merge) (0) | 2020.01.16 |
DI (Dependency Injection) 의존 주입 (0) | 2020.01.15 |