inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

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

Hello JPA - 애플리케이션 개발

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

해결된 질문

315

염경호

작성한 질문수 12

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하려할 때 모두 테이블 값이 초기화되면서 아무것도 값을 가져오지 못하는 상황이 발생하는데 설정 문제인지 계속 롤백이 되도록 되어있는 것인지 궁금하여 질문드립니다. 링크도 첨부하겠습니다

java jpa

답변 1

0

OMG

안녕하세요. 염경호님, 공식 서포터즈 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

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

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

감사합니다.

1

염경호

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

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

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

벌크연산에서 member.getAge 호출 시 영속성 컨텍스트에서 데이터를 가져오는건가요?

0

24

2

inheritance startegy 선택시 고려사항

0

22

1

Entity 동등성 비교

0

18

1

실무 조언 관련 질문입니다.

0

46

1

H2데이터베이스 파일 생성

0

56

2

서브쿼리 강의에서 ALL 예시 관련 질문드립니다.

0

52

2

수정또는 삭제시 영속성 엔티티에 값이 무조건 있어야 하나요?

0

52

1

JPQL 메소드와 락

0

55

1

Delivery @OneToOne

0

60

1

17강 4~5분대 테이블 값 조회가 안됩니다.

0

93

2

UnsupportedOperationException 발생

0

86

3

H2 Database 연결이 안됩니다.

0

92

2

연관관계 매핑 질문드립니다.

0

85

2

h2데이터베이스 실행오류

0

107

2

persistence.xml

0

106

2

양방향 연관관계에서 연관관계의 주인(mappedBy)을 왜 꼭 정해야 하나요?

0

80

1

영속성 컨텍스트

0

65

1

JPA 프록시

0

95

1

Native Query와 MyBatis

0

68

1

영속성 컨텍스트는 어떤 메모리에 저장되는건가요?

0

85

1

임베디드 타입 예시 코드 관련 질문

0

114

3

명시적 조인에서 별칭을 주면 왜 객체에 접근할 수 있나요

0

94

3

인텔리제이 패키지 커서 단축키 질문

0

108

2

혹시 현재는 ID 데이터 타입이 String이면 안되나요?

0

143

1