강의

멘토링

로드맵

Inflearn Community Q&A

wkadht06194497's profile image
wkadht06194497

asked

Java ORM Standard JPA Programming - Basics

Persistence Context 2

em.find 관련 질문입니다

Written on

·

247

·

Edited

0

public class JpaMain {

    public static void main(String[] args) {

        EntityManagerFactory emf = Persistence.createEntityManagerFactory("hello");
        EntityManager em = emf.createEntityManager();
        //code

        EntityTransaction tx = em.getTransaction();
        tx.begin();

        try {
            Member findMember1 = em.find(Member.class, 101L);
            Member findMember2 = em.find(Member.class, 101L);

            tx.commit();
        } catch (Exception e) {
            tx.rollback();
        } finally {
            em.close();
        }

        emf.close();

    }
}

위 코드를 실행하면 select 쿼리가 한번만 나가야 하는데 저 같은 경우는 두번 나가고 h2에서 id가 101인 엔티티도 사라집니다. 왜 그런가요?

아래는 실행했을 때 로그에 뜨는 쿼리입니다
Hibernate: 
    select
        m1_0.id,
        m1_0.name 
    from
        Member m1_0 
    where
        m1_0.id=?
Hibernate: 
    select
        m1_0.id,
        m1_0.name 
    from
        Member m1_0 
    where
        m1_0.id=?
javajpa

Answer 1

0

안녕하세요. lll님, 공식 서포터즈 y2gcoder입니다.

혹시 id가 101인 Member가 H2 DB에 저장되어 있을까요? 첫번째 em.find()에서 해당하는 엔티티를 가져와서 영속화하지 못했기 때문에 두번째 em.find()에서도 select 문이 나가는 것 같습니다!

감사합니다.

III님의 프로필 이미지
III
Questioner

도와주신 말씀이 맞았습니다. 감사합니다.

wkadht06194497's profile image
wkadht06194497

asked

Ask a question