인프런 커뮤니티 질문&답변

염경호님의 프로필 이미지
염경호

작성한 질문수

자바 ORM 표준 JPA 프로그래밍 - 기본편

Hello JPA - 애플리케이션 개발

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

해결된 질문

작성

·

91

1

학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.

1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)

질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)

[질문 내용]

링크 : https://drive.google.com/drive/folders/1VfZnK2GoZrg7pMOsahW0ERZVXFL_w_6X?usp=drive_link
강의를 듣다가 의문이 생겨서 질문 드립니다. 코드를 작성하여 table에 값들을 저장하고 이후에 update를 em.find()를 통해 하려하거나 그동안 저장했던 member값들을 em.createQuery하려할 때 모두 테이블 값이 초기화되면서 아무것도 값을 가져오지 못하는 상황이 발생하는데 설정 문제인지 계속 롤백이 되도록 되어있는 것인지 궁금하여 질문드립니다. 링크도 첨부하겠습니다

답변 1

0

안녕하세요. 염경호님, 공식 서포터즈 OMG입니다.

프로젝트 코드 확인해보았습니다.

테이블이 초기화 되는 가능성이 현재 2가지 포인트로 확인이됩니다.

(1) 명시적인 롤백

해당 상황은 코드에서 예외가 발생했을 때 명시적으로 롤백이 됩니다.

이미 저장되어 있던 모든 데이터를 삭제하진 않겠지만, 작업 중의 변경사항은 롤백이 되어 작업 내역이 반영 되지 않을 수 있습니다.

image.png

이 때는 출력문을 추가하여 확인해볼 수 있습니다.(예외 발생 시 출력)

tx.rollback();
e.printStackTrace(); // 추가

 

(2) 테이블 초기화 설정

persistence.xml의 아래 밑줄 친 value값이 create로 되어 있습니다.

create는 애플리케이션 실행 시 모든 테이블을 드랍(drop) 후 새로 생성(create) 합니다.

image.png

create로 인한 영향을 없애려면 value를 none으로 변경하면 됩니다.

<property name="hibernate.hbm2ddl.auto" value="none" />

 

코드 실행결과

try {
    Member member1 = new Member();
    Member member2 = new Member();
    member1.setId(1L);
    member1.setName("helloA");
    member2.setId(2L);
    member2.setName("helloB");
    em.persist(member1);
    em.persist(member2);
    //이렇게 작성하고 이후 result출력하려하면 아무값도 없다고 나오고 h2데이터베이스 테이블을 전체 조회해봐도 값이 다 없어집니다 em.find의 경우도 동일한 현상이 발생합니다
    List<Member> result = em.createQuery("select m from Member as m", Member.class).getResultList();
    for (Member member : result) {
        System.out.println("member.name = " + member.getName());
    }
    tx.commit();
}catch(Exception e){
    tx.rollback();
    e.printStackTrace();
}finally{
    em.close();
}

실행 시 저의 경우 정상적으로 조회됩니다.

image.png

위에 설명드린 포인트를 적용하여 확인햐보시겠어요?

해결이 안될 경우 댓글 남겨주세요

감사합니다.

염경호님의 프로필 이미지
염경호
질문자

방금 실행해봤는데 쿼리도 정상적으로 날라가고 동작 잘 하는 것 같습니다!(iter돌리는 거랑 em.find 다 정상적으로 돌아가집니다)

<property name="hibernate.hbm2ddl.auto" value="none" />

이 코드로 수정하니깐 잘 됩니다. 감사합니다!!

염경호님의 프로필 이미지
염경호

작성한 질문수

질문하기