작성
·
247
0
들은 강의를 기반으로 Member 클래스와 1대 다로 매핑되는 Community를 구현하려 합니다.
Community는 추상 클래스입니다.
1. 위와 같은 경우에는 Repository를 CommunityReposity 외에도 NoticeRepository와 QnARepository를 구현해야하나요..?
1.2. NoticeRepository와 QnARepository를 구현해야한다면 CommunityService 외에도 NoticeService와 QnAService도 따로 구현해줘야하나요?
관련된걸 찾아보려해도 repository나 service 생성에 관한 내용을 찾아볼 수가 없어서 질문 드립니다......ㅠㅠ
답변 5
2
1
1
안녕하세요. Nam님
결론부터 말씀드리면 아마 이 설계에는 다형성이 필요 없으실꺼에요.
단순히 Communtity 테이블 하나만 사용하고, 내부에 type 필드를 만들어서 구분하시는게 더 좋을 것 같아요.
다형성을 사용하려면 그 다형성의 가치가 있을 때 사용해야 하는데, (내부 필드를 거의 숨기고 메서드를 오버라이드해서 다형성을 활용하기 좋을 때) 지금은 효과가 크게 없을 것 같습니다. (그래서 실무에서 다형성을 활용하는 경우도 많지 않습니다.)
다형성을 활용할 때는 거의 부모 엔티티를 대상으로 한 리포지토리만 만들 때 효과가 있습니다.
추가로 꼭 필요할 때는 자식 엔티티를 대상으로 한 리포지토리도 추가로 만들어야 합니다.
도움이 되셨길 바래요^^
0
0
그럼 굳이 @Inheritance(strategy = InheritancType.JOINED)를 쓸 필요 없이 SINGLE_TABLE을 써도 되겠군요!!
처음에는 Single_table을 활용해서 dtype으로 구분할 수 있을까 라는 생각으로 알아보던 도중에 방법이 없다는걸 깨달았습니다.
그 후, JOINED가 더 괜찮을 수도 있다는 생각을 해서 여쭤보게됐습니다ㅎㅎ
Type 필드를 추가하면 된다고 왜 생각을 못 했을까요!!
덕분에 길을 찾았습니다 감사합니다ㅎㅎ