• 카테고리

    질문 & 답변
  • 세부 분야

    백엔드

  • 해결 여부

    미해결

em.find 관련 질문입니다

24.03.22 16:38 작성 24.03.22 16:40 수정 조회수 75

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=?

답변 1

답변을 작성해보세요.

0

y2gcoder님의 프로필

y2gcoder

2024.03.22

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

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

감사합니다.

III님의 프로필

III

질문자

2024.03.22

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