제대로 이해한 게 맞을까요? + 오타 제보 + setter 추가 질문
354
작성한 질문수 83
수정하려는 엔티티의 키가 10이라고 했을 때,
1. DB에는 아직 수정 전인 엔티티가 들어있음. 이건 영속.
2. Book book = new Book(); 한 후 BookForm의 정보들로 set해줌. 이건 그냥 함수 내에서 new로 만들었을 뿐이니 JPA가 관리하고 있지 않음. 하지만 이 book의 키값인 10은 디비에 저장되어있음. 그래서 이건 준영속.
(즉, 10이란 키값을 갖는 엔티티에 대해 영속 엔티티와 준영속 엔티티가 동시에 존재하는 상황.)
3. 여기서 준영속 엔티티 book의 key값으로 검색하여 영속 엔티티 findItem을 가져오고 값을 덮어씌움.
4. 모든 작업 이후에도 book은 여전히 준영속 엔티티이므로 더이상 사용하지 않는 것이 좋음.
+
5. 결국 더티체킹 메서드를 직접 만들든, em.merge()를 사용하든 내부적으로는 전부 더티체킹을 사용하여 update하는 것임.
(null 업데이트 문제는 제쳐두고)
이런 흐름이 맞나요? merge의 과정보다도 merge 실행 전에 같은 키값의 영속,준영속이 동시에 존재하는 부분이 맞는지가 더 모르겠고 궁금하네요.
감사합니다!
ㅡㅡㅡㅡㅡㅡㅡㅡ
19:53에서 맨 윗줄에 '재'한적이다 오타 제보드립니다.
ㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡㅡ
(추가질문)
setter를 경계하라는 말씀을 다시 한 번 해주셨는데요. "change()처럼 엔티티에 변경 메서드를 따로 만들면 추적이 쉽다" 라는 말씀에서 이해가 좀 안 가는 부분이 있습니다.
setter로 변경을 하더라도 그 setter명으로 역추적하면 변경지점이 어디인지 알 수 있는 것 아닌가요?
혹시 여러 엔티티에서 같은 이름의 멤버변수를 가지는 경우엔 setter이름도 같아져서 찾기 어렵다는 말씀이신가요?
답변 1
2
안녕하세요. 현강님
생각하신 흐름이 맞습니다
오타 제보 감사합니다 ㅎㅎ 다음 메뉴얼 배포때 같이 수정할게요^^
추가질문
엔티티의 내용을 변경할 때 모든 내용을 다 setter로 열어두게 되면 외부에서 해당 setter를 자유롭게 막 호출해서 변경하게 됩니다.
물론 추적할 수 있지만 프로젝트의 범위가 너무 커지면 점점 찾기가 어려워지고 마구 호출이 일어나지요.
대신에 의미있는 이름을 부여하고 변경이 필요없는 setter를 열어두지 않는 것이 중요합니다.
단순히 해당 필드 수 만큼 changeXxx()를 만들라는 의미는 아니고, 꼭 수정이 필요한 필드에 한정해서 만들라는 의미입니다.
도움이 되셨길 바래요^^
OrderServiceTest 상문주문 테스트 시 update 쿼리 문의
0
30
1
sdk 설정 오류
0
72
2
오탈자 - @Transactional
0
68
1
src/test/resources 테스트 경로 문제
0
68
1
상품 등록후 H2 db 출력 순서 바꿀 수 있나요?
0
71
1
MemberRepositoryTest 실행오류
0
91
1
boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)
1
198
2
강의 마지막 QueryDSL 사용 부분 질문있습니다
1
154
2
클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.
0
58
1
도메인 모델 패턴 vs 트랜잭션 스크립트 패턴
0
82
1
기본 생성자
0
67
1
h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.
0
107
1
멤버서비스테스트 부분에서 막힙니다.
0
176
4
실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?
0
125
1
초반에 h2 다운로드 과정 꼭 필요한가요?
0
129
2
자신 필드에도 get으로 접근하는 이유가 있을까요?
0
122
1
24분 27초 연관관계 편의 메서드 위치
0
118
1
단건 주문만 가능하게 한건 의도한 부분이신가요?
0
115
2
빌드 툴, Gradle
0
65
1
h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다
0
82
2
Repository에서 EntityManager 주입 방식 차이
0
98
1
롬복과 사용자 정의 setter 메서드
0
78
1
주문 목록 조회 fetch join 질문드립니다
0
91
1
dirty checking 질문드립니다.
0
88
1





