JPA에서 가장 중요한 2가지 아래와 같다.
엔티티를 영구 저장하는 환경
이라는 뜻새로운
상태// 객체를 생성한 상태(비영속)
Member member = new Member();
member.setId("member1");
member.setName("sayho");
관리
되는 상태// 객체를 생성한 상태(비영속)
Member member = new Member();
member.setId("member1");
member.setName("sayho");
EntityManager em = emf.createEntityManager();
em.getTransaction().begin();
//객체를 저장한 상태(영속)
em.persist(member); // 단, 이때는 아직 쿼리가 DB로 날아가지 않으며 Transaction.commit() 시점에 날아가게 된다.
분리된
상태// 회원 엔티티를 영속성 컨텍스트에서 분리(준영속)
em.detach(member);
삭제된
상태// 객체를 삭제한 상태(삭제)
em.remove(member);
key
: @Id로 선언한 필드 값, value
: Entity가 저장된다.Member a = em.find(Member.class, "member1");
Member b = em.find(Member.class, "member1");
System.out.println(a == b); // 동일성 비교 true
EntityManager em = emf.createEntityManager();
EntityTransaction transaction = em.getTransaction();
transaction.begin(); // 트랜잭션 시작
em.persist(memberA);
em.persist(memberB);
// 여기까지 INSERT SQL을 데이터베이스에 보내지 않는다.
// 커밋하는 순간 데이터베이스에 SQL을 보낸다.(SQL FLUSH)
transaction.commit(); // 트랜잭션 커밋
쓰기 지연 SQL 저장소
에 INSERT SQL을 저장해서 쌓아 놓는다.commit()
하는 시점에 쿼리들을 DB에 보낸다.(동시에 다 보내는 방식 or 하나씩 옵션에 맞게 보내는 방식)flush()
인데 이는 1차 캐시를 지우지는 않고, DB와 싱크를 맞추는 역할을 한다.flush()
와 commit()
을 동시에 하는 것이며 flush()
를 따로 처리할 수 있다.EntityManager em = emf.createEntityManager();
EntityTransaction transaction = em.getTransaction();
transaction.begin(); // 트랜잭션 시작
// 영속 엔티티 조회
Member memberA = em.find(Member.class, "memberA");
// 영속 엔티티 데이터 수정
memberA.setUsername("sayhooooya");
memberA.setAge(7);
transaction.commit(); // 트랜잭션 커밋
find()
를 통해 memberA를 가져올 때, 1차 캐시에 저장하게 되는데스냅샷
을 생성한다.쓰기 지연 SQL 저장소
에 저장한다.commit()
또는 flush()
가 일어날 시, 쿼리를 DB에 날린다.em.clear()
clear()
를 하게되면 같은 엔티티를 가져와도 쿼리문이 중복해서 나간다. (1차 캐시 또한 초기화 되므로)em.close()