data:image/s3,"s3://crabby-images/e8695/e8695b580633c43f5156fb7112d7c49096a3cab3" alt="DTO 바로 받기 (ORM으로 해결 안 될 경우) - 1"
[ 조회를 하는데 DTO로 바로 받는 것 ]
data:image/s3,"s3://crabby-images/bcfdb/bcfdbc2065d83b19554763f03e408f315c05d8a9" alt="notion image"
id, title, content 하고나서, 게시글에 있는 댓글 갯수(카운트)를 뽑아야할 경우가 있다.
data:image/s3,"s3://crabby-images/d7aa1/d7aa1ba567cf90a11c6d0ccbbcce9794e4c80f8f" alt="notion image"
이런식으로 나오게끔 뽑아보자!! 근데 이렇게 생긴 엔티티가 없지않나? 4자리(board_id 자리)에 서브쿼리가 들어가야한다. 이런 결과가 나오는 쿼리는 아래에.
select id, title, content, user_id, (select count(id) from reply_tb where board_id = bt.id) reply_count from board_tb bt;
where board_id = bt.id 현재 조회 중인 게시글의 ID와 reply_tb 테이블의 board_id가 일치하는 댓글만을 세라 그런데 엔티티로는 이런 데이터를 못받는다. QLRM 안쓰고, 이런걸 받을땐 네이티브쿼리나 오브젝트 배열로 받았잖아? JPQL은 간단하게 가능
[ JPQL DTO ]
data:image/s3,"s3://crabby-images/6c9e0/6c9e004fb0ad6901f0aaad3a011df7fd7a348204" alt="notion image"
이렇게 count를 못 쓰기 때문에 이걸 받을 수 있는 DTO를 만들어준다
[ BoardCountDTO ]
data:image/s3,"s3://crabby-images/046e6/046e61ff37013c811219a5e900be3631e47b8261" alt="notion image"
static 없어도 되는걸까?
[ BoardJPARepository ] - JPARepository DTO 매핑하기
@Query("select new shop.mtcoding.blog.board.BoardCountDTO(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<BoardCountDTO> findAllWithReplyCount();
패키지명을 new로 가져오는데, 풀로 적어서 가져와야함!!
BoardJPARepository는 return할 때 Board 타입밖에 안 됨. (UserJPARepository는 User 타입만 리턴하겠지...) JPARepository는 DTO 매핑이 되지 않는다! 그러나 이 문법을 적으면 DTO 매핑 가능!
[ 테스트 하다가 ]
data:image/s3,"s3://crabby-images/84d45/84d458355d3c6c2a69adb39bd722e70e72d8d1fa" alt="notion image"
//return 값 = List<BoardCountDTO>
[ 에러 ]
data:image/s3,"s3://crabby-images/50357/50357a507292c278e4734e8387c38ca3e578481e" alt="notion image"
data:image/s3,"s3://crabby-images/874e8/874e8d07e08613f98117e0b1adc1b2c7ff51859e" alt="notion image"
생성자 없고, 타입 안 맞아서 터졌네?
[ BoardCountDTO 한테 ]
data:image/s3,"s3://crabby-images/cd7ee/cd7eeaa6df59e83d8c66ab889a8bff3648e0c81e" alt="notion image"
생성자를 주고, 카운트 타입 친거는 Long 타입으로 바꿔야함 (다른것들도 래핑시켜주자)
[ 다시 테스트하면? ]
data:image/s3,"s3://crabby-images/588d8/588d811de5dd6656558590b415de008f2114dab9" alt="notion image"
data:image/s3,"s3://crabby-images/64f51/64f51da5cd696e8d85a5e59f38f41d28d27294e4" alt="notion image"
data:image/s3,"s3://crabby-images/aad42/aad420844ed0e1bafec3105ee8bcbc8926c89d57" alt="notion image"
data:image/s3,"s3://crabby-images/e484c/e484cf7d7f0d6ce07d0c37afb5524f50f26e41cb" alt="notion image"
data:image/s3,"s3://crabby-images/3f3bc/3f3bca417a497d470054259417720c3b45cb7e0d" alt="notion image"
댓글 1,2,3,4 다 나왔죠? 좋죠? 이거 쓰세요 ^^
Share article