- JPQL : 엔티티 객체를 대상으로 쿼리
- SQL : 데이터베이스 테이블을 대상으로 쿼리
- 한마디로 정의하자면 JPQL은 객체 지향 SQL문이다.
EntityManager.persist(entity);
- 단순히
entity
에 들어가는 객체를 DB에 저장하는 것보다 좀 더 깊은 의미가 있다.- 처음부터 DB에 저장되는 것이 아니라 영속성 컨텍스트라는 곳에 저장한다.
insert
동작은commit
시점에 실행된다.
비영속(new/transient) : 영속성 컨텍스트와 전혀 관계없는 새로운 상태
persist()
로 관리 시작
영속(managed) : 영속성 컨텍스트에 관리되는 상태
detach()
,clear()
,close()
로 분리remove()
로 삭제
em.detach(entity)
: 특정 엔티티만 준영속 상태로 전환em.clear()
: 영속성 컨텍스트를 완전히 초기화em.close()
: 영속성 컨텍스트를 종료
준영속(detached) : 영속성 컨텍스트에 저장되었다가 분리된 상태
merge()
로 다시 관리
삭제(removed) : 삭제된 상태
persist()
로 다시 관리
@id
로 테이블의 기본 키와 매핑한 값)으로 구분한다.flush
(플러쉬)commit
시에 전체 트랜잭션을 실시한다.tx.begin(); em.persist(memberA); em.persist(memberB); // 여기까지 Insert SQL을 데이터베이스에 보내지 않고 저장한다 tx.commit(); // commit하는 순간 Insert SQL을 보낸다
flush()
호출 시 JPA는 엔티티와 스냅샷을 비교해 변경을 감지했을 경우(Dirty Checking
) 자동으로 UPDATE
SQL문을 생성해 쓰기 지연 저장소에 저장했다가 커밋한다. tx.begin(); // 조회 Member memberA = em.find(Member.class, "memberA"); // 영속 엔티티 데이터 수정 memberA.setUsername("hi"); memberA.setAge(10); // 별도의 update 코드 없이도 update 가능 tx.commit();
em.flush()
-> 직접 호출tx.commit()
또는 JPQL
쿼리 실행 -> 자동 호출