작성
·
881
1
답변 1
1
안녕하세요, vnfthr 님. 공식 서포터즈 codesweaver 입니다.
.
하나의 답이 있는 질문은 아니라고 생각합니다. 저도 현업에서 mybatis를 이용하고 있는데요, 저의 경우를 말씀드리겠습니다..
우선 View에서 오는 데이터는 FormDTO 객체를 이용해서 받습니다. 그리고 이 DTO를 서비스에서 필요한 값 연산이나 처리등을 거친 뒤 이를 리포지토리에 전달하고 리포지토리에서는 단순이 mybatis 호출을 하며 이 DTO를 그대로 전달합니다.
.
그리고 mybatis에서 쿼리를 할 때, 필요한 필드 값만을 추출(질문하신 것 중에선 1번의 경우가 됩니다) 이를 Entity로 반환합니다. 엔티티가 테이블과 일치하지 않습니다. 즉, 테이블에 존재하는 필드여도엔티티의 멤버 변수가 없을 수 있습니다(필요한 경우 엔티티의 멤버 변수를 추가합니다). 그리고 이 엔티티를 그대로 뷰까지 전달합니다. 사실상 엔티티 없이 DTO만 있는 상태입니다.
.
개인적으로 mybatis를 사용하면서 엔티티를 가져가야할 이유가 있는가 하는 생각이 있습니다. DTO만 이용하는 방법이 코드를 더 간결하게 유지한다고 생각합니다, 다만 mybatis에서 JPA로의 전환을 고려한다면 지금과 같은 형태는 매우 난감한 상황입니다. (사실 기존에 돌고 있는 서비스를 JPA로 바꾸는 일은 어떤 상황이더라도 쉽지 않을거라 생각하지만요)
.
'프로젝트의 규모에 따라 변칙적인 구조를 갖는게 코드를 더 깔끔하게 유지할 수 있는 방법이 될 수도 있다' 정도로 참고만 해주시기 바랍니다. (그런데 왜 새롭게 하시는 프로젝트에서 mybatis를 사용하려고 하시는지 궁금하네요. mybatis 쿼리 매핑하고 resultType 작성하다보면 내가 왜 이짓거리 하고 있나 생각이 드실텐데요 (도망))
감사합니다.
이런식으로 dto와 엔티티를 분리해야한다는 생각에 서비스에서 dto를 엔티티로 컨버팅하는 과정에서 쓸때없이 코드가 많아지는것 같습니다..(보통 이런식으로 jpa를 많이 사용 하는것으로 알고 있습니다)
굳이 이렇게 할 필요는 없겠죠..?
마이바티스를 쓰는 이유는 당장 쿼리짜는 능력도 부족한데 jpa를 하는건 어불성설이 아닌가 라는 생각에 하고 있습니다 그냥 도전해보는것도 괜찮을까요?