data:image/s3,"s3://crabby-images/9243b/9243bfa367f9579dc734cb2cd3fd08c3e83cb0aa" alt="DTO 바로 받기 $사용 (ORM으로 해결 안 될 경우) - 2"
[ 쿼리문 ]
select id, title, content, user_id, (select count(id) from reply_tb where board_id = bt.id) reply_count from board_tb bt;
[ 뽑고자 하는 데이터 ]
data:image/s3,"s3://crabby-images/5da15/5da157998d7d3cf03d44722992ef80a43318ebf5" alt="notion image"
[ BoardResponse ] - Count용 DTO 생성
@AllArgsConstructor @Data public class CountDTO { private Integer id; private String title; private String content; private Integer userId; private Long replyCount; }
[ BoardJPARepository ] - BoardQueryRepository로 해도 될 듯
data:image/s3,"s3://crabby-images/3d948/3d9488717fe79816855462bc3922ff49ebca1ec4" alt="notion image"
@Query("select new shop.mtcoding.blog.board.BoardResponse$CountDTO(b.id, b.title, b.content, b.user.id, (select count(r.id) from Reply r where r.board.id = b.id)) from Board b") List<BoardResponse.CountDTO> findAllWithReplyCount();
data:image/s3,"s3://crabby-images/cd9e1/cd9e1891815678f2741c2ffbcda11d204b92c056" alt="notion image"
$ 를 써줬다! $를 써줘야 돌아감!
[ 테스트 ]
@Test public void findAllWithReplyCount_test(){ // given // when List<BoardResponse.CountDTO> boardCountDTOList = boardJPARepository.findAllWithReplyCount(); System.out.println(boardCountDTOList); // then }
Share article