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()