결과 화면


코드
Requset
{ "username":"ssar", "password":"1234" }
controller
@GetMapping("/api/category/{categoryId}/posts") public ResponseEntity<?> listPostsByCategory( @PathVariable("categoryId") Integer categoryId, @RequestParam(defaultValue = "1") int page, HttpServletRequest request ) { PostResponse.ListDTO model = postService.공고리스트(categoryId, page); return ResponseEntity.ok() .header("Authorization", "Bearer " + request.getHeader("Authorization")) // 토큰을 그대로 반환 .body(Resp.ok(model)); }
Service
public PostResponse.ListDTO 공고리스트(Integer categoryId, int page) { //추후 비동기로 페이지별 리스트 가져가기 Pageable pageable = PageRequest.of(page - 1, 3); // 페치 조인으로 리뷰 포함된 포스트들 가져오기 List<Post> bestSellingPosts = postRepository.findAllPostsOrderBySales(); List<Post> recentPosts = postRepository.findAllPostsOrderByCreatedAtDesc(); return new PostResponse.ListDTO(recentPosts, bestSellingPosts); }
repository
@Query("SELECT p " + "FROM Post p " + "LEFT JOIN Product pr ON p.id = pr.post.id " + "LEFT JOIN Inventory i ON pr.id = i.product.id " + "LEFT JOIN OrderDetail od ON i.id = od.inventory.id " + "GROUP BY p.id " + "ORDER BY COALESCE(SUM(od.count), 0) DESC") List<Post> findAllPostsOrderBySales(); @Query("SELECT DISTINCT p FROM Post p LEFT JOIN FETCH p.reviews r ORDER BY p.createdAt DESC") List<Post> findAllPostsOrderByCreatedAtDesc();
요청과 결과 Json
{ "status": 200, "msg": "성공", "body": { "recentPostsDTOS": [ { "id": 1, "title": "편안한침대 시몬스", "content": "편안한 시몬스 침대는 최고의 편안함을 제공합니다.", "price": 1200000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/1050/1046/1046294_A1.jpg?v=20240906134132", "createdAt": "2024-10-18T01:28:11.361+00:00", "reviews": [ { "id": 1, "content": "시몬스 침대를 구매했는데 정말 편안하고 좋습니다.", "url": "review1.jpg", "star": 4.5, "createdAt": "2024-10-18" }, { "id": 2, "content": "매트리스가 부드럽고 프레임도 튼튼해서 만족합니다.", "url": "review2.jpg", "star": 5.0, "createdAt": "2024-10-18" } ] }, { "id": 2, "title": "최고의침대 에이스", "content": "에이스 침대는 편안한 수면을 위한 최고의 선택입니다.", "price": 800000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/1050/1064/1064629_A1.jpg?v=20241002161516", "createdAt": "2024-10-18T00:28:11.361+00:00", "reviews": [ { "id": 3, "content": "에이스 침대는 가성비가 뛰어납니다.", "url": "review3.jpg", "star": 4.0, "createdAt": "2024-10-18" }, { "id": 4, "content": "프레임 디자인이 마음에 들고, 수면 품질이 좋아졌습니다.", "url": "review4.jpg", "star": 4.8, "createdAt": "2024-10-18" } ] }, { "id": 3, "title": "안락한침대 한샘", "content": "한샘의 안락한 침대는 넉넉한 공간을 제공합니다.", "price": 1500000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/992/992693_A1.jpg?v=20240812104935", "createdAt": "2024-10-17T23:28:11.361+00:00", "reviews": [ { "id": 5, "content": "킹사이즈 침대 정말 넉넉하고 좋아요!", "url": "review5.jpg", "star": 5.0, "createdAt": "2024-10-18" } ] }, { "id": 4, "title": "편안한침대 템퍼", "content": "템퍼의 편안한 침대는 편안한 수면을 보장합니다.", "price": 1400000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/800/800342_A1.jpg?v=20240723101452", "createdAt": "2024-10-17T22:28:11.361+00:00", "reviews": [] }, { "id": 5, "title": "럭셔리침대 슬로우베드", "content": "슬로우베드의 럭셔리 침대는 프리미엄 수면을 제공합니다.", "price": 1700000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/974/974970_A1.jpg?v=20241011152438", "createdAt": "2024-10-17T21:28:11.361+00:00", "reviews": [] }, { "id": 6, "title": "편안한침대 시몬스", "content": "시몬스의 최신형 편안한 침대는 지지력과 편안함을 제공합니다.", "price": 1600000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/993/993015_A1.jpg?v=20240812104316", "createdAt": "2024-10-17T20:28:11.361+00:00", "reviews": [] }, { "id": 7, "title": "최고의침대 에이스", "content": "에이스의 프리미엄 침대는 깊은 수면을 위한 최고의 제품입니다.", "price": 1800000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/934/934707_A1.jpg?v=20241014083653", "createdAt": "2024-10-17T19:28:11.361+00:00", "reviews": [] }, { "id": 8, "title": "안락한침대 한샘", "content": "한샘의 안락한 침대는 편안한 수면을 제공합니다.", "price": 1300000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/1025/1025752_A1.jpg?v=20241002145703", "createdAt": "2024-10-17T18:28:11.361+00:00", "reviews": [] }, { "id": 9, "title": "편안한침대 템퍼", "content": "템퍼의 프리미엄 침대는 지지력과 편안함을 극대화합니다.", "price": 1500000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/978/978544_A1.jpg?v=20241002160612", "createdAt": "2024-10-17T17:28:11.361+00:00", "reviews": [] }, { "id": 10, "title": "럭셔리침대 슬로우베드", "content": "슬로우베드의 최고급 침대는 고객의 만족을 보장합니다.", "price": 1900000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/1021/1021051_A1.jpg?v=20241015085531", "createdAt": "2024-10-17T16:28:11.361+00:00", "reviews": [] } ], "pageTotalSoldDtos": [ { "id": 1, "title": "편안한침대 시몬스", "content": "편안한 시몬스 침대는 최고의 편안함을 제공합니다.", "price": 1200000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/1050/1046/1046294_A1.jpg?v=20240906134132", "createdAt": "2024-10-18T01:28:11.361+00:00", "reviews": [ { "id": 1, "content": "시몬스 침대를 구매했는데 정말 편안하고 좋습니다.", "url": "review1.jpg", "star": 4.5, "createdAt": "2024-10-18" }, { "id": 2, "content": "매트리스가 부드럽고 프레임도 튼튼해서 만족합니다.", "url": "review2.jpg", "star": 5.0, "createdAt": "2024-10-18" } ] }, { "id": 2, "title": "최고의침대 에이스", "content": "에이스 침대는 편안한 수면을 위한 최고의 선택입니다.", "price": 800000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/1050/1064/1064629_A1.jpg?v=20241002161516", "createdAt": "2024-10-18T00:28:11.361+00:00", "reviews": [ { "id": 3, "content": "에이스 침대는 가성비가 뛰어납니다.", "url": "review3.jpg", "star": 4.0, "createdAt": "2024-10-18" }, { "id": 4, "content": "프레임 디자인이 마음에 들고, 수면 품질이 좋아졌습니다.", "url": "review4.jpg", "star": 4.8, "createdAt": "2024-10-18" } ] }, { "id": 3, "title": "안락한침대 한샘", "content": "한샘의 안락한 침대는 넉넉한 공간을 제공합니다.", "price": 1500000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/992/992693_A1.jpg?v=20240812104935", "createdAt": "2024-10-17T23:28:11.361+00:00", "reviews": [ { "id": 5, "content": "킹사이즈 침대 정말 넉넉하고 좋아요!", "url": "review5.jpg", "star": 5.0, "createdAt": "2024-10-18" } ] }, { "id": 4, "title": "편안한침대 템퍼", "content": "템퍼의 편안한 침대는 편안한 수면을 보장합니다.", "price": 1400000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/800/800342_A1.jpg?v=20240723101452", "createdAt": "2024-10-17T22:28:11.361+00:00", "reviews": [] }, { "id": 5, "title": "럭셔리침대 슬로우베드", "content": "슬로우베드의 럭셔리 침대는 프리미엄 수면을 제공합니다.", "price": 1700000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/974/974970_A1.jpg?v=20241011152438", "createdAt": "2024-10-17T21:28:11.361+00:00", "reviews": [] }, { "id": 6, "title": "편안한침대 시몬스", "content": "시몬스의 최신형 편안한 침대는 지지력과 편안함을 제공합니다.", "price": 1600000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/993/993015_A1.jpg?v=20240812104316", "createdAt": "2024-10-17T20:28:11.361+00:00", "reviews": [] }, { "id": 7, "title": "최고의침대 에이스", "content": "에이스의 프리미엄 침대는 깊은 수면을 위한 최고의 제품입니다.", "price": 1800000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/934/934707_A1.jpg?v=20241014083653", "createdAt": "2024-10-17T19:28:11.361+00:00", "reviews": [] }, { "id": 8, "title": "안락한침대 한샘", "content": "한샘의 안락한 침대는 편안한 수면을 제공합니다.", "price": 1300000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/1025/1025752_A1.jpg?v=20241002145703", "createdAt": "2024-10-17T18:28:11.361+00:00", "reviews": [] }, { "id": 9, "title": "편안한침대 템퍼", "content": "템퍼의 프리미엄 침대는 지지력과 편안함을 극대화합니다.", "price": 1500000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/978/978544_A1.jpg?v=20241002160612", "createdAt": "2024-10-17T17:28:11.361+00:00", "reviews": [] }, { "id": 10, "title": "럭셔리침대 슬로우베드", "content": "슬로우베드의 최고급 침대는 고객의 만족을 보장합니다.", "price": 1900000, "mainPhoto": "https://image.hanssem.com/hsimg/gds/330/1021/1021051_A1.jpg?v=20241015085531", "createdAt": "2024-10-17T16:28:11.361+00:00", "reviews": [] } ] } }
Share article