작성
·
1.3K
0
학습하는 분들께 도움이 되고, 더 좋은 답변을 드릴 수 있도록 질문전에 다음을 꼭 확인해주세요.
1. 강의 내용과 관련된 질문을 남겨주세요.
2. 인프런의 질문 게시판과 자주 하는 질문(링크)을 먼저 확인해주세요.
(자주 하는 질문 링크: https://bit.ly/3fX6ygx)
3. 질문 잘하기 메뉴얼(링크)을 먼저 읽어주세요.
(질문 잘하기 메뉴얼 링크: https://bit.ly/2UfeqCG)
질문 시에는 위 내용은 삭제하고 다음 내용을 남겨주세요.
=========================================
[질문 템플릿]
1. 강의 내용과 관련된 질문인가요? (예/아니오)
2. 인프런의 질문 게시판과 자주 하는 질문에 없는 내용인가요? (예/아니오)
3. 질문 잘하기 메뉴얼을 읽어보셨나요? (예/아니오)
[질문 내용]
안녕하세요 영한님.
얼마전에 스타트업에 신입 백엔드 개발자로 입사하였고, 작년부터 영한님 강의를 꾸준히 들어오던 수강생 입니다!
저희 회사는 데이터 접근 기술로써 Query DSL로 통일되어 있었는데요,
왜 Spring Data JPA를 사용하지 않냐고 대표님께 문의드리자, Query DSL로 모든 기능을 다 수행할 수 있기에,
코드의 일관성과 학습 기술을 줄이기 위해서 라고 답변 받았습니다.
그러나 저는 애초에 JPA를 사용하는 근본적인 이유중 하나가 바로 직접 SQL을 작성하지 않기 때문이라고 생각하고 있기 때문에 , Spring Data JPA를 사용하는게 어떻겠냐고 다시 한번 문의드리고 싶은 상황입니다.
영한님 께서 신입으로 입사한 저의 입장이셨다면, 문의를 드렸을지 생각을 여쭙고 싶습니다.
항상 좋은 강의 및 답변 감사합니다.
답변 1
0
JPA로는 한계가 분명합니다. 기본적으로 3번이상의 조인이 발생할 경우, 또는 조건절의 파라미터가 여러가지일 경우, jpql을 사용하지 않는 한 스프링 데이터 jpa의 메소드 명칭자체가 가독성을 현저하게 떨어트립니다. 이런 단점을 매꾸는 라이브러리가 queryDsl이며, 그러한 관점에 있어서 해당 업체의 대표님께서 다른 이들의 러닝커브까지 생각한 것 같습니다. 단순하게 queryDsl는 jpql 빌더이며, myBatis를 도입하는 것 보다, jpa를 도입한 이유에 포커스를 두셔야 할 것 같습니다. 어떠한 기술의 도입 이유는 해당 기술의 탄생이념보단, 업체의 기술스택을 정하는 사람의 몫이기 때문입니다.
실제로 업계에서 기술스택을 정할때는 업체 대표님들 또는 CTO 분들께서 충분히 고려하고 선정하는 부분이기에 영한님께 여쭤보는 것 보단 그분들하고 이야기를 해보시는게 더 적합하지 않을까 싶습니다. 실제로 querydls은 이미 jpa에 의존하기 때문에 사실상 jpa를 사용하냐 mybatis를 사용하냐로 나눠지는게 맞지 않을까 싶습니다
저의 경우는 사이드 프로젝트를 진행할 때 ,
간단한 쿼리는 Spring Data JPA 를 사용하였고,
그 외 복잡한 동적쿼리는 Query DSL로 사용하였는데요 ,
그럼에도 불구하고 이건 저의 스타일이고 , 실제 업계에서 어떤 기술을 선정해서 쓰는지는 대표님의 몫이라는 말씀이신거죠?