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

asdkfur님의 프로필 이미지

작성한 질문수

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

회원 서비스 개발

CQRS

해결된 질문

작성

·

1.3K

14

안녕하세요. 정말 좋은 강의 항상 잘 듣고 있습니다.

Repository save 메서드는 Member 를 반환하기보다는 id를 반환하는 식으로 구성하셨는데 이게 기본편에서 커맨드와 커리를 분리한기위함이라고 하셨던걸로 기억합니다.

이론적으로는 조회와 insert update 등을 분리한다고 는 이해했는데 실제 웹 어플리케이션 개발떄 이로써는 얻는 이점에 대해 좀더 자세히 들을수있을까요? 그리고 실제 실무에서는 어느정도까지 분리해서 보통 사용하나요?

답변 2

31

김영한님의 프로필 이미지
김영한
지식공유자

안녕하세요. asdkfur님^^ 좋은 질문입니다.

제가 강의에서 말씀드린 부분은 정확히는 CQRS가 아니라 CQS 입니다^^

이게 웹 애플리케이션에서 얻는 이점이 있다기 보다는, 개발 전반에 기본개념으로 깔고 가시는 것이 좋습니다.

이 메서드를 호출 했을 때, 내부에서 변경(사이드 이펙트)가 일어나는 메서드인지, 아니면 내부에서 변경이 전혀 일어나지 않는 메서드인지 명확히 분리하는 것이지요.

그렇게 되면 데이터 변경 관련 이슈가 발생했을 때, 변경이 일어나는 메서드만 찾아보면 됩니다^^

정말 크리티컬한 이슈들은 대부분 데이터를 변경하는 곳에서 발생하지요.

변경 메서드도 변경에만 집중하면 되기 때문에 유지보수가 더 좋아집니다.

제가 권장하는 방법은 insert는 id만 반환하고(아무것도 없으면 조회가 안되니), update는 아무것도 반환하지 않고, 조회는 내부의 변경이 없는 메서드로 설계하면 좋습니다^^

감사합니다.

1

asdkfur님의 프로필 이미지
asdkfur
질문자

정말 항상 자세하고 빠른 답변 감사합니다. 

asdkfur님의 프로필 이미지

작성한 질문수

질문하기