해결된 질문
작성
·
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) 명시적인 롤백
해당 상황은 코드에서 예외가 발생했을 때 명시적으로 롤백이 됩니다.
이미 저장되어 있던 모든 데이터를 삭제하진 않겠지만, 작업 중의 변경사항은 롤백이 되어 작업 내역이 반영 되지 않을 수 있습니다.
이 때는 출력문을 추가하여 확인해볼 수 있습니다.(예외 발생 시 출력)
tx.rollback();
e.printStackTrace(); // 추가
(2) 테이블 초기화 설정
persistence.xml의 아래 밑줄 친 value값이 create로 되어 있습니다.
create는 애플리케이션 실행 시 모든 테이블을 드랍(drop) 후 새로 생성(create) 합니다.
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();
}
실행 시 저의 경우 정상적으로 조회됩니다.
위에 설명드린 포인트를 적용하여 확인햐보시겠어요?
해결이 안될 경우 댓글 남겨주세요
감사합니다.
방금 실행해봤는데 쿼리도 정상적으로 날라가고 동작 잘 하는 것 같습니다!(iter돌리는 거랑 em.find 다 정상적으로 돌아가집니다)
<property name="hibernate.hbm2ddl.auto" value="none" />
이 코드로 수정하니깐 잘 됩니다. 감사합니다!!