stock을 entity로 분류 하는 이유
268
작성한 질문수 16
안녕하세요 선생님!
초심자인 저에게 코드가 어렵지만 그림 그려 가면서
이해 하고 있습니다.
내용을 이해 하던 중 도메인에 궁금한게 생겼습니다.
선생님께서는 stock을 따로 entity로 분류 하셨습니다.
그런데 저는 "상품에 재고가 있어도 되지 않나?"
라는 생각이 들었는데
따로 stock을 분류 하신 이유가 궁금합니다.
product에 수량을 추가 한다면
수량이 필요 없는 필드도 수량 필드를 가지게 되는데
데이터가 많을 경우 db에 부담이 되기 때문 일까요?
답변 1
4
안녕하세요, 조희제 님!
물론 그렇게 할 수도 있고, 예제가 간단한 편이라 그렇게 관리하는 것도 가능하겠지만, 실무에서 '재고'라는 개념은 정말 많은 이해관계가 얽혀 있기에 따로 관리하는 것이 좋습니다.
말씀주신 '재고가 필요 없는 상품'도 재고 정보를 가지게 되기도 하고, '재고'라는 개념과 관련된 수많은 메타 정보가 같이 저장되어야 하기도 합니다.
'상품' 이라는 개념도 정말 많은 데이터를 가지게 될 것이고요.
동시성 문제도 고려되어야 할텐데, 상품과 재고가 같이 관리되는 대용량 테이블에 이러한 것들을 모두 적용하는 것은 상당히 부담이 되겠죠.
정리하면, 상품도 복잡한 도메인일 뿐더러 재고 자체만 해도 고려해야 할 사항들이 많기 때문에, 상품의 전체 데이터에 재고를 같이 넣는 것 보다는 별도로 관리하는 것이 더 좋다는 의견입니다.
도움이 되셨기를 바랍니다.
감사합니다 🙂
private 상수 테스트 관련 질문
0
82
1
void는 어떻게 테스트하나요..? void로 애초에 코딩하면 안되나요??
0
124
2
커버리지는 어떻게 활용하시는지 궁금합니다.
0
159
2
테스트 문서화 질문입니다
0
104
2
단위테스트 질문이 있습니다
0
95
2
컨트롤러는 모킹을 한 이유가 궁금합니다.
0
100
2
ERD 가장자리에 있는 도메인 테스트 질문
0
87
2
DTO 검증 필드에 대한 테스트 코드 작성은 어디까지?
0
132
2
OrderCreateRequest DTO에 대해서 궁금한점
0
101
2
고전파의 테스트 대역 사용 대상, 공유 의존성
0
154
2
계층 관련 질문이 있습니다.
0
137
3
'코틀린'에서는 빌더를 따로 쓰지 않는데, 이 때는 어떻게 test fixture를 만드시는지 궁금합니다
1
122
2
혹시 update 로직은 어떻게 테스트하나요? (@Setter?)
0
133
2
단위테스트와 통합테스트의 경계가 궁금합니다.
0
227
2
Service+Repository 통합테스트 관련 질문입니다.
0
149
2
OrderControllerDocsTest 작성 해봤는데요. 날짜 형식이 이상하게 나와요
0
183
2
test 용 .yml
0
89
2
throws Exception
0
78
2
카페키오스크 클래스 문의 ,,
0
87
2
Rest docs 문서용 테스트코드를 따로 작성해야 되나요?
0
172
2
테스트 코드에서 필요한 생성자
0
137
1
tearDown 순서
0
115
2
@Builder 생성자 private
0
135
2
@DisplayName gradle / intellJ
0
92
2





