ProductSearchImpl 관련 질문드립니다.
106
작성한 질문수 3
@Override
public PageResponseDTO<ProductDTO> searchList(PageRequestDTO pageRequestDTO) {
log.info("----------------------searchList-------------------------");
Pageable pageable = PageRequest.of(
pageRequestDTO.getPage() -1,
pageRequestDTO.getSize(),
Sort.by("pno").descending());
QProduct product = QProduct.product;
QProductImage productImage = QProductImage.productImage;
// from 절
JPQLQuery<Product> query = from(product);
// join
// @ElementCollection을 join 할때는 아래와 같이 사용해야합니다.
// product.imageList를 productImage로 사용하겠다.
query.leftJoin(product.imageList, productImage);
query.where(productImage.ord.eq(0));
Objects.requireNonNull(getQuerydsl()).applyPagination(pageable,query);
List<Tuple> productList = query.select(product,productImage).fetch(); // 쿼리를 실행시키기 위함.
long count = query.fetchCount();
log.info("=======================");
log.info(productList);
return null;
}이 코드에서 return 값을 넘기고 싶어서 수정하는데 어떻게 해야 값이 넘어가는지를 잘 모르겠습니다...
TodoSearchImpl에서는 new PageImpl<>() 사용하셔서 넘기셨는데 여기서는 어떻게 처리해야 될까요??
2. ProductServiceImpl의 getList() 메서드와 동일한 역할인거같은데, ProductSearchImpl 에서는 querydsl을 사용하셔서 보여주신거고 ProductServiceImpl에서는 jpa를 사용하는 방법을 보여주신게 맞는지 궁금합니다!
답변 2
1
List<Tuple>에 있는 내용을 List<ProductDTO> 로 변환하시는 작업이 필요합니다.
PageRequestDTO는 파라미터에 있는 것을 그대로 사용하시면 되고..
이를 활용해서 아래와 같은 코드로 리턴하실 수 있습니다.
PageResponseDTO<ProductDTO> responseDTO = PageResponseDTO.<ProductDTO>withAll()
.dtoList(dtoList)
.pageRequestDTO(pageRequestDTO)
.totalCount(totalCount)
.build();
return responseDTO;
2번은 말씀하신 내용이 맞습니다.
0
안녕하세요, 인프런 AI 인턴입니다.
질문하신 내용과 유사한 문제를 해결한 기존의 답변을 찾았습니다. 예시 코드와 함께 설명된 답변 링크가 도움이 될 것 같습니다.
검색 결과 반환 값 처리에 대해서는 다음 질문에서 유사한 상황을 해결하는 과정이 설명되어 있습니다. 해당 답변에서는
PageResponseDTO를 생성하고 반환하는 방법에 대해 안내하고 있습니다. 구체적으로는 결과 목록과 페이지 정보를 활용해PageResponseDTO의 인스턴스를 생성하고 반환하는 방법에 대해 설명하고 있습니다.- PageResponseDTO 오에서
@Builder를 이용한 객체 생성 방법이 설명되고 있으며, 이를 활용해 검색된 데이터 목록과 페이지 정보를 담은 DTO 객체를 생성하는 방법이 제시되어 있습니다. 이 예시는TodoServiceImpl에서의 사용 예를 보여주나,ProductSearchImpl에서의 사용법도 유사하게 적용할 수 있습니다.
- PageResponseDTO 오에서
ProductSearchImpl에서 Querydsl을 사용한 검색 방법과ProductServiceImpl에서 JPA를 사용하는 방법이 서로 다른 접근 방식을 보여주는 것이 맞습니다. 각각의 접근 방식은 상황에 따라 선택적으로 사용할 수 있으며, 특정 쿼리의 복잡성이나 성능 요건에 따라 적절한 기술을 선택하여 사용하는 것이 좋습니다.
이러한 작업에서 중요한 것은 비즈니스 로직에 맞게 데이터를 처리하고, 필요에 따라 JPA와 Querydsl 중 어느 것을 사용할지 결정하는 것입니다. JPA는 좀 더 일반적인 데이터 액세스 작업에 적합할 수 있고, Querydsl은 복잡한 쿼리 작업이 필요할 때 더 유리할 수 있습니다.
저는 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해드리고 있습니다.
현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏
추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
동일하게 실습하는데 이상하게 페이지를 찾지 못하네요..
0
74
2
22. REST 방식 컨트롤러 만들기(2), 29. 등록처리 부분 질문이 있습니다.
0
74
2
37강. 강의수업듣다 질문드립니다.
0
57
2
TodoDTO test 함수
0
80
3
강사님 오타 있음요
0
78
2
No 1. 교제(ppt) soruce 복붙 문제 의 건
0
95
4
No 1. 교제(ppt) soruce 복붙 문제 의 건
0
70
3
17강 문의드립니다.
0
44
1
카카오 연동설정이 이제 안되는거 같아요
0
193
2
8장 마지막 강의 시 오류
0
98
4
혹시 뭐가 문제인지 알 수 있나요?
0
87
2
챕터: React-Router 설정
0
58
2
백)TODO관련
0
56
2
마리아 db 설치중 포트를 이미 사용중이라고 합니다
0
112
2
이강의 듣고 소화시켰다면 몇년차 정도 개발자라고 할수 있을까요?
0
105
1
CSR , SSR 의 수요 궁금증 질문
0
83
2
섹션5부터...
0
73
1
간단한 코드 질문!!
0
61
2
tbl_todo 질문입니다
0
65
2
수업 외 질문인데 'tbl'이 무슨 의미인가요???
0
292
2
엔티티클래스에서 질문입니다
0
78
2
수정시 writer값이 삭제되는 오류
0
42
2
교안 31 오타 수정해주세요
0
64
2
쿠키에 accessToken, refreshToken을 담고, 조회 시에 undefined
0
80
1





