inflearn logo
강의

강의

N
챌린지

챌린지

멘토링

멘토링

N
클립

클립

로드맵

로드맵

지식공유

실전! 스프링 부트와 JPA 활용1 - 웹 애플리케이션 개발

주문 검색 기능 개발

안녕하세요! 동적쿼리에 대한 질문이 있습니다.

537

치즈초코우유

작성한 질문수 13

0

현재 2년차가 되가고 있는 주니어개발자입니다 ( _ _)

아직 경험이 많이 없어 현재 쿼리를 처리하는 퍼시스턴트 프레임워크를 mybaits 정도 밖에 써보지 못 했습니다

선생님께서 말씀하신 것처럼 쿼리를 JPQL로 작성해서 처리할 수 있다고 하셨는데...

아래는 제가 mybatis로 api 처리하고 있는 쿼리입니다. 이런 다소 지저분하고 복잡한 쿼리도 실무에서는 JPQL로 처리를 하나요??? 

SELECT /* windowClosingPosData */
b.paymentType
,MAX(b.gdName) as gdName
,b.payMethod
,SUM(b.personCnt) as personCnt /* 수량 */
,SUM(b.price) as price /* 금액 */
,SUM(b.discountCount) as discountCnt /* 할인매수 */
,SUM(b.discountAmount) as discount /* 할인금액 */
FROM (
SELECT
a.paymentType
,a.gdName
,a.payMethod
,(
CASE
WHEN a.paymentType = 'PAY'
THEN a.ticketCount
WHEN a.paymentType = 'CANCEL'
THEN a.refundCount
ELSE 0
END
) as personCnt /* 수량 */
,(
CASE
WHEN a.paymentType = 'PAY'
THEN a.ticketAmount
WHEN a.paymentType = 'CANCEL'
THEN a.refundAmount
ELSE 0
END
) as price /* 금액 */

,a.discountCount /* 할인 수량 */
,a.discountAmount /* 할인 금액 */

FROM (
SELECT
'PAY' as paymentType
,gd.gd_name as gdName
,pm.pm_pay_method as payMethod
,rd.init_rs_ticket_cnt as ticketCount /* 발권매수 */
,(rd.init_rs_ticket_cnt * rd_price) as ticketAmount /* 발권금액 */
,0 as refundCount /* 환불매수 */
,0 as refundAmount /* 환불금액 */
,(
CASE
WHEN ifnull(rd.dc_unit_price,0) > 0
THEN rd.init_rs_ticket_cnt
ELSE 0
END
) as discountCount /* 할인매수 */
,(rd.init_rs_ticket_cnt * rd.dc_unit_price) as discountAmount
FROM t_reserve_detail rd
INNER JOIN t_reserve rs
ON rd.rs_seq = rs.rs_seq
INNER JOIN t_goods gd
ON rs.gd_seq = gd.gd_seq
INNER JOIN t_payment pm
ON rs.rs_seq = pm.rs_seq
AND pm.pm_payment_type = 'PAY'
WHERE
EXISTS (
SELECT
trdp.rs_seq
FROM t_reserve_detail_person trdp
WHERE trdp.tkt_date = DATE_FORMAT(#{searchDate}, '%Y%m%d')
AND trdp.idkey = #{idkey}
AND trdp.tkt_win_cd = #{winCd}
AND trdp.rs_seq = rs.rs_seq
)
AND (rs.gd_package_yn = 'Y' OR (rs.rs_package_yn = 'N' AND rs.gd_package_yn = 'N'))
AND rs.insert_idkey = #{memberSeq}
UNION ALL
SELECT
'CANCEL' as paymentType
,gd.gd_name as gdName
,pm.pm_pay_method as payMethod
,0 as ticketCount /* 발권매수 */
,0 as ticketAmount /* 발권금액 */
,rd.cancel_ticket_cnt as refundCount /* 환불매수 */
,(rd.cancel_ticket_cnt * rd_price) as refundAmount /* 환불금액 */
,0 as discountCount /* 할인매수 */
,0 as discountAmount
FROM t_reserve_detail rd
INNER JOIN t_reserve rs
ON rd.rs_seq = rs.rs_seq
INNER JOIN t_goods gd
ON rs.gd_seq = gd.gd_seq
INNER JOIN t_payment pm
ON rs.rs_seq = pm.rs_seq
AND pm.pm_payment_type = 'PAY'
WHERE
EXISTS (
SELECT
trdp.rs_seq
FROM t_reserve_detail_person trdp
WHERE trdp.tkt_date = DATE_FORMAT(#{searchDate}, '%Y%m%d')
AND trdp.idkey = #{idkey}
AND trdp.cancel_win_cd = #{winCd}
AND trdp.cancel_member_seq = #{memberSeq}
AND trdp.rs_seq = rs.rs_seq
)
AND (rs.gd_package_yn = 'Y' OR (rs.rs_package_yn = 'N' AND rs.gd_package_yn = 'N'))
AND rs.rs_status = 'D'
) a
) b
GROUP BY b.paymentType
,b.payMethod
ORDER BY b.payMethod, b.paymentType DESC

JPQL 강의도 들을 계획이지만 이렇게 복잡한 부분을 java단에서 처리한다는게 상상이 되지 않아서 질문드려봅니다 ㅠㅠ

jpql spring java spring-boot 웹앱 JPA

답변 1

0

김영한

안녕하세요. 하준님

JPA를 사용하더라도 복잡한 통계성 쿼리는 네이티브 SQL을 직접 사용하는 편입니다.

추가로 JPA는 from 절의 서브쿼리가 지원되지 않기 때문에, 이런 경우에도 네이티브 SQL을 사용해야 합니다.

관련해서 JPQL을 학습해보시면, 장점과 한계점을 함께 학습하실 수 있을거에요.

화이팅!

0

치즈초코우유

친절한 답변 너무 감사합니다! 최근에 너무 바빠서 강의만 듣고 실습은 못하고 있는데ㅠㅠ

꼭 실습까지 다시한번 완료해서 제껄로 만들겠습니다!! 감사합니다!!!

0

김영한

백문이 불여일타입니다! 실습 필수! ㅋㅋ 화이팅!

sdk 설정 오류

0

49

2

오탈자 - @Transactional

0

55

1

src/test/resources 테스트 경로 문제

0

50

1

상품 등록후 H2 db 출력 순서 바꿀 수 있나요?

0

63

1

MemberRepositoryTest 실행오류

0

81

1

boot 4.x >>> trasasction rolled back log & p6spy(영한님, 수업 자료 업데이트 해주시면 감사하겠습니다!!)

1

183

2

강의 마지막 QueryDSL 사용 부분 질문있습니다

1

137

2

클라이언트에서 isbn과 author 수정 요청을 한 경우에 대해 질문드립니다.

0

51

1

도메인 모델 패턴 vs 트랜잭션 스크립트 패턴

0

71

1

기본 생성자

0

60

1

h2 DB 연결시 jdbc url 변경 이유가 궁금합니다.

0

100

1

멤버서비스테스트 부분에서 막힙니다.

0

164

4

실무에서도 EntityManager를 이용해서 많이 작업하는 편일까요?

0

116

1

초반에 h2 다운로드 과정 꼭 필요한가요?

0

118

2

자신 필드에도 get으로 접근하는 이유가 있을까요?

0

112

1

24분 27초 연관관계 편의 메서드 위치

0

113

1

단건 주문만 가능하게 한건 의도한 부분이신가요?

0

108

2

빌드 툴, Gradle

0

59

1

h2연결은 된 것 같은데 엔티티 테이블까지 작성 후 확인해보아도 테이블이 안보입니다

0

76

2

Repository에서 EntityManager 주입 방식 차이

0

88

1

롬복과 사용자 정의 setter 메서드

0

71

1

주문 목록 조회 fetch join 질문드립니다

0

81

1

dirty checking 질문드립니다.

0

81

1

동시성 관련 질문입니다

0

73

1