청구검증 백엔드

This commit is contained in:
Jeon
2023-07-05 10:20:09 +09:00
parent 03566d283c
commit 07df97bebe
7 changed files with 533 additions and 0 deletions

View File

@@ -450,4 +450,21 @@ public class SysMgtController {
return sysService.svcCheckLists(svcCheckListReqDto); return sysService.svcCheckLists(svcCheckListReqDto);
} }
/**
* date : 2023. 7. 3.
* auth : Jeon
* desc : 청구검증 목록 조회
* @param monthListReqDto
* @param bindingResult
* @return
*/
@ApiOperation(value = "verification", notes = "월별 통계 목록 조회")
@ApiResponses({ @ApiResponse(code = HttpServletResponse.SC_OK, message = "SUCESS") })
@RequestMapping(value = "/verification" , method = {RequestMethod.POST})
@ResponseBody
public VerificationResDto verification() {
return sysService.getVerificationList();
}
} }

View File

@@ -59,4 +59,6 @@ public interface SysMgtMapper {
int notiListSelectCnt(NotiListReqDto notiListReqDto); int notiListSelectCnt(NotiListReqDto notiListReqDto);
List<VerificationDto> getVerificationList();
} }

View File

@@ -743,4 +743,26 @@ public class SysMgtService {
return new SvcCheckListResDto(ApiResponseCode.SUCCESS,svcCheckListRes); return new SvcCheckListResDto(ApiResponseCode.SUCCESS,svcCheckListRes);
} }
/**
* date : 2023. 7. 3.
* auth : Jeon
* desc : 청구검증 목록 조회
* @return
*/
public VerificationResDto getVerificationList() {
SysMgtMapper sysmgtmapper = sqlSessionSlave.getMapper(SysMgtMapper.class);
VerificationRes verificationRes = new VerificationRes();
List<VerificationDto> verificationDtoList = sysmgtmapper.getVerificationList();
verificationRes.setList(verificationDtoList);
Paging paging = new Paging();
paging.setTotalCnt(String.valueOf(verificationDtoList.size()));
verificationRes.setPaging(paging);
return new VerificationResDto(ApiResponseCode.SUCCESS, verificationRes);
}
} }

View File

@@ -0,0 +1,98 @@
package kr.co.uplus.ez.api.sysMgt.dto;
import java.io.Serializable;
import io.swagger.annotations.ApiModelProperty;
import lombok.Data;
@SuppressWarnings("serial")
@Data
public class VerificationDto implements Serializable {
@ApiModelProperty(example = "고객사", name = "고객사", dataType = "String")
private String custNm;
@ApiModelProperty(example = "사업자번호", name = "사업자번호", dataType = "String")
private String bizrno;
@ApiModelProperty(example = "유큐브등록번호", name = "유큐브등록번호", dataType = "String")
private String entrNo;
@ApiModelProperty(example = "상품명", name = "상품명", dataType = "String")
private String prodNm;
@ApiModelProperty(example = "가입일", name = "가입일", dataType = "String")
private String opnDt;
@ApiModelProperty(example = "일할대상", name = "일할대상", dataType = "String")
private String dayUser;
@ApiModelProperty(example = "상태", name = "상태", dataType = "String")
private String dtlCdNm;
@ApiModelProperty(example = "성공건수", name = "성공건수", dataType = "String")
private String succCnt;
@ApiModelProperty(example = "전달 정액요금", name = "전달 정액요금", dataType = "String")
private String fxLmtAmt;
@ApiModelProperty(example = "전달 이월금액", name = "전달 이월금액", dataType = "String")
private String cfwdAmt;
@ApiModelProperty(example = "전달 소멸금액", name = "전달 소멸금액", dataType = "String")
private String extncAmt;
@ApiModelProperty(example = "전달 소멸충전금액", name = "전달 소멸충전금액", dataType = "String")
private String extcChrgAmt;
@ApiModelProperty(example = "전달 이월충전금액", name = "전달 이월충전금액", dataType = "String")
private String cfwdChrgAmt;
@ApiModelProperty(example = "전달 소멸충전복원", name = "전달 소멸충전복원", dataType = "String")
private String extcChrgRsrt;
@ApiModelProperty(example = "전달 이월충전복원", name = "전달 이월충전복원", dataType = "String")
private String cfwdChrgRsrt;
@ApiModelProperty(example = "전달 소멸충전잔액", name = "전달 소멸충전잔액", dataType = "String")
private String extcChrgBlnc;
@ApiModelProperty(example = "전달 이월충전잔액", name = "전달 이월충전잔액", dataType = "String")
private String cfwdChrgBlnc;
@ApiModelProperty(example = "과금금액", name = "과금금액", dataType = "String")
private String mrtUseAmt;
@ApiModelProperty(example = "신규 이월금액", name = "신규 이월금액", dataType = "String")
private String nowCfwdAmt;
@ApiModelProperty(example = "예상 이월금액", name = "예상 이월금액", dataType = "String")
private String estCfwdAmt;
@ApiModelProperty(example = "이월금액 일치결과", name = "이월금액 일치결과", dataType = "String")
private String rsltStr;
@ApiModelProperty(example = "총 사용금액", name = "총 사용금액", dataType = "String")
private String totalUseAmt;
@ApiModelProperty(example = "알림톡 사용금액", name = "알림톡 사용금액", dataType = "String")
private String kkoNotiUseAmt;
@ApiModelProperty(example = "SMS 사용금액", name = "SMS 사용금액", dataType = "String")
private String smsUseAmt;
@ApiModelProperty(example = "LMS 사용금액", name = "LMS 사용금액", dataType = "String")
private String lmsUseAmt;
@ApiModelProperty(example = "MMS 사용금액", name = "MMS 사용금액", dataType = "String")
private String mmsUseAmt;
@ApiModelProperty(example = "일할 정액요금", name = "일할 정액요금", dataType = "String")
private String lmtPerUseDay;
@ApiModelProperty(example = "할인율", name = "할인율", dataType = "String")
private String discount = "0";
@ApiModelProperty(example = "유큐브 청구금액", name = "유큐브 청구금액", dataType = "String")
private String billAmt = "0";
}

View File

@@ -0,0 +1,17 @@
package kr.co.uplus.ez.api.sysMgt.dto;
import java.io.Serializable;
import java.util.List;
import kr.co.uplus.ez.common.data.Paging;
import lombok.Data;
@SuppressWarnings("serial")
@Data
public class VerificationRes implements Serializable {
private List<VerificationDto> list;
private Paging paging;
}

View File

@@ -0,0 +1,32 @@
package kr.co.uplus.ez.api.sysMgt.dto;
import java.io.Serializable;
import io.swagger.annotations.ApiModelProperty;
import kr.co.uplus.ez.common.data.ApiResponseCode;
import kr.co.uplus.ez.common.data.ResponseMessage;
import lombok.Data;
@SuppressWarnings("serial")
@Data
public class VerificationResDto extends ResponseMessage implements Serializable {
@ApiModelProperty(example = "데이터")
private VerificationRes data;
public VerificationResDto() {
this.retCode = ApiResponseCode.SUCCESS.getResultCode();
this.retMsg = ApiResponseCode.SUCCESS.getResultMsg();
}
public VerificationResDto(ApiResponseCode returnStr) {
this.retCode = ApiResponseCode.SUCCESS.getResultCode();
this.retMsg = ApiResponseCode.SUCCESS.getResultMsg();
}
public VerificationResDto(ApiResponseCode returnStr, VerificationRes data) {
this.retCode = ApiResponseCode.SUCCESS.getResultCode();
this.retMsg = ApiResponseCode.SUCCESS.getResultMsg();
this.data = data;
}
}

View File

@@ -522,4 +522,349 @@
</if> </if>
</if> </if>
</select> </select>
<select id="getVerificationList" resultType="kr.co.uplus.ez.api.sysMgt.dto.VerificationDto">
SELECT
CUST_NM
,A.BIZRNO
,A.ENTR_NO
,A.PROD_NM
,A.OPN_DT
,A.DAY_USER
,A.DTL_CD_NM
,A.SUCC_CNT
,A.FX_LMT_AMT
,A.LMT_PER_USE_DAY
,A.CFWD_AMT
,A.EXTNC_AMT
,A.EXTC_CHRG_AMT
,A.CFWD_CHRG_AMT
,A.EXTC_CHRG_RSRT
,A.CFWD_CHRG_RSRT
,A.EXTC_CHRG_BLNC
,A.CFWD_CHRG_BLNC
,FORMAT(A.MRT_USE_AMT,0) AS MRT_USE_AMT
,FORMAT(A.NOW_CFWD_AMT,0) AS NOW_CFWD_AMT
,CONCAT(IF(A.EST_CFWD_AMT <![CDATA[ < ]]> 0,'(과금)',''),FORMAT(ABS(A.EST_CFWD_AMT),0)) AS EST_CFWD_AMT
,IF((A.EST_CFWD_AMT <![CDATA[ < ]]> 0 AND (A.MRT_USE_AMT + A.EST_CFWD_AMT) = 0) OR (A.EST_CFWD_AMT = A.NOW_CFWD_AMT),'일치','불일치') AS RSLT_STR
,A.TOTAL_USE_AMT
,A.KKO_NOTI_USE_AMT
,A.SMS_USE_AMT
,A.LMS_USE_AMT
,A.MMS_USE_AMT
FROM (
SELECT
CUST_NM
,A.USER_SEQ
,A.CUST_SEQ
,A.SUBS_ID
,A.BIZRNO
,A.ENTR_NO
,A.PROD_CD
,A.PROD_NM
,A.OPN_DT
,A.SUBS_STTUS_CD
,A.DTL_CD_NM
,FORMAT(A.FX_LMT_AMT,1) AS FX_LMT_AMT
,FORMAT(A.CFWD_AMT,1) AS CFWD_AMT
,FORMAT(A.EXTNC_AMT,1) AS EXTNC_AMT
,FORMAT(A.CFWD_RSTRT_BLNC,1) AS CFWD_RSTRT_BLNC
,A.MRT_USE_AMT
,FORMAT(A.EXTC_CHRG_AMT,1) AS EXTC_CHRG_AMT
,FORMAT(A.CFWD_CHRG_AMT,1) AS CFWD_CHRG_AMT
,FORMAT(A.EXTC_CHRG_RSRT,1) AS EXTC_CHRG_RSRT
,FORMAT(A.CFWD_CHRG_RSRT,1) AS CFWD_CHRG_RSRT
,FORMAT(A.EXTC_CHRG_BLNC,1) AS EXTC_CHRG_BLNC
,FORMAT(A.CFWD_CHRG_BLNC,1) AS CFWD_CHRG_BLNC
,A.NOW_CFWD_AMT
,(CASE
WHEN A.SUBS_STTUS_CD = '99'
THEN 0
ELSE (IF(A.SUBS_STTUS_CD IN ('03','04') AND A.USE_DAY IS NULL,0,(ROUND((A.FX_LMT_AMT/LAST_DT)*IFNULL(A.USE_DAY,LAST_DT))))
+ A.CFWD_AMT - A.EXTNC_AMT - A.TOTAL_USE_AMT
+ (A.EXTC_CHRG_AMT - (A.EXTC_CHRG_RSRT+A.EXTC_CHRG_BLNC)) + (A.CFWD_CHRG_RSRT + A.CFWD_CHRG_BLNC))
END) AS EST_CFWD_AMT
,IF(A.SUBS_STTUS_CD IN ('03','04') AND A.USE_DAY IS NULL,0,(ROUND((A.FX_LMT_AMT/LAST_DT)*IFNULL(A.USE_DAY,LAST_DT)))) AS LMT_PER_USE_DAY
,A.TOTAL_USE_AMT
,A.KKO_NOTI_USE_AMT
,A.SMS_USE_AMT
,A.LMS_USE_AMT
,A.MMS_USE_AMT
,A.REQ_CNT
,A.SUCC_CNT
,A.SMS
,A.LMS
,A.MMS
,A.SMS_GLOBAL
,A.RCS
,A.KKO_NOTI
,A.KKO_FRIEND
,A.SMS_FB
,A.LMS_FB
,A.MMS_FB
,A.SMS_FAIL
,A.LMS_FAIL
,A.MMS_FAIL
,A.SMS_GLOBAL_FAIL
,A.RCS_FAIL
,A.KKO_NOTI_FAIL
,A.KKO_FRIEND_FAIL
,A.SMS_WAIT
,A.LMS_WAIT
,A.MMS_WAIT
,A.KKO_NOTI_WAIT
,A.USE_DAY
,IF(A.LAST_DT = A.USE_DAY,'비대상','대상') AS DAY_USER
FROM (
SELECT
ECI.CUST_NM
,ECI.BIZRNO
,A.ENTR_NO
,A.PROD_CD
,EPI.PROD_NM
,A.OPN_DT
,A.SUBS_STTUS_CD
,ECD.DTL_CD_NM
,ECI.CUST_SEQ
,A.USER_SEQ
,A.SUBS_ID
,A.FX_LMT_AMT
,A.CFWD_AMT
,A.EXTNC_AMT
,A.CFWD_RSTRT_BLNC
,A.MRT_USE_AMT
,A.NOW_CFWD_AMT
,A.EXTC_CHRG_AMT
,A.CFWD_CHRG_AMT
,A.EXTC_CHRG_RSRT
,A.CFWD_CHRG_RSRT
,A.EXTC_CHRG_BLNC
,A.CFWD_CHRG_BLNC
,((A.KKO_NOTI+A.KKO_NOTI_WAIT) * A.KKO_NOTI_COST) AS KKO_NOTI_USE_AMT
,((A.SMS+A.SMS_FB+A.SMS_WAIT) * A.SMS_COST) AS SMS_USE_AMT
,((A.LMS+A.LMS_FB+A.LMS_WAIT) * A.LMS_COST) AS LMS_USE_AMT
,((A.MMS+A.MMS_FB+A.MMS_WAIT) * A.MMS_COST) AS MMS_USE_AMT
,((A.KKO_NOTI+A.KKO_NOTI_WAIT) * A.KKO_NOTI_COST)
+((A.SMS+A.SMS_FB+A.SMS_WAIT) * A.SMS_COST)
+((A.LMS+A.LMS_FB+A.LMS_WAIT) * A.LMS_COST)
+((A.MMS+A.MMS_FB+A.MMS_WAIT) * A.MMS_COST) AS TOTAL_USE_AMT
,A.REQ_CNT
,(A.SMS + A.LMS + A.MMS + A.SMS_GLOBAL + A.RCS + A.KKO_NOTI + A.KKO_FRIEND + A.SMS_FB + A.LMS_FB + A.MMS_FB) AS SUCC_CNT
,A.SMS
,A.LMS
,A.MMS
,A.SMS_GLOBAL
,A.RCS
,A.KKO_NOTI
,A.KKO_FRIEND
,A.SMS_FB
,A.LMS_FB
,A.MMS_FB
,A.SMS_FAIL
,A.LMS_FAIL
,A.MMS_FAIL
,A.SMS_GLOBAL_FAIL
,A.RCS_FAIL
,A.KKO_NOTI_FAIL
,A.KKO_FRIEND_FAIL
,A.SMS_WAIT
,A.LMS_WAIT
,A.MMS_WAIT
,A.KKO_NOTI_WAIT
,A.KKO_NOTI_COST
,A.SMS_COST
,A.LMS_COST
,A.MMS_COST
,IF(USETB.USE_DAY <![CDATA[ < ]]> 0,NULL,USETB.USE_DAY) AS USE_DAY
,DATE_FORMAT(LAST_DAY(DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m01')),'%d') AS LAST_DT
FROM (
SELECT
LMT.USER_SEQ
,LMT.ENTR_NO
,LMT.PROD_CD
,LMT.OPN_DT
,LMT.SUBS_STTUS_CD
,LMT.FX_LMT_AMT
,LMT.CFWD_AMT
,LMT.EXTNC_AMT
,LMT.CFWD_RSTRT_BLNC
,LMT.MRT_USE_AMT
,LMT.NOW_CFWD_AMT
,LMT.EXTC_CHRG_AMT
,LMT.CFWD_CHRG_AMT
,LMT.EXTC_CHRG_RSRT
,LMT.CFWD_CHRG_RSRT
,LMT.EXTC_CHRG_BLNC
,LMT.CFWD_CHRG_BLNC
,LMT.KKO_NOTI_COST
,LMT.SMS_COST
,LMT.LMS_COST
,LMT.MMS_COST
,LMT.SUBS_ID
,MAX(LMT.CUST_SEQ) AS CUST_SEQ
,IFNULL(SUM(VRF.REQ_CNT),0) AS REQ_CNT
,IFNULL(SUM(VRF.SMS),0) AS SMS
,IFNULL(SUM(VRF.LMS),0) AS LMS
,IFNULL(SUM(VRF.MMS),0) AS MMS
,IFNULL(SUM(VRF.SMS_GLOBAL),0) AS SMS_GLOBAL
,IFNULL(SUM(VRF.RCS),0) AS RCS
,IFNULL(SUM(VRF.KKO_NOTI),0) AS KKO_NOTI
,IFNULL(SUM(VRF.KKO_FRIEND),0) AS KKO_FRIEND
,IFNULL(SUM(VRF.SMS_FB),0) AS SMS_FB
,IFNULL(SUM(VRF.LMS_FB),0) AS LMS_FB
,IFNULL(SUM(VRF.MMS_FB),0) AS MMS_FB
,IFNULL(SUM(VRF.SMS_FAIL),0) AS SMS_FAIL
,IFNULL(SUM(VRF.LMS_FAIL),0) AS LMS_FAIL
,IFNULL(SUM(VRF.MMS_FAIL),0) AS MMS_FAIL
,IFNULL(SUM(VRF.SMS_GLOBAL_FAIL),0) AS SMS_GLOBAL_FAIL
,IFNULL(SUM(VRF.RCS_FAIL),0) AS RCS_FAIL
,IFNULL(SUM(VRF.KKO_NOTI_FAIL),0) AS KKO_NOTI_FAIL
,IFNULL(SUM(VRF.KKO_FRIEND_FAIL),0) AS KKO_FRIEND_FAIL
,IFNULL(SUM(VRF.SMS_WAIT),0) AS SMS_WAIT
,IFNULL(SUM(VRF.LMS_WAIT),0) AS LMS_WAIT
,IFNULL(SUM(VRF.MMS_WAIT),0) AS MMS_WAIT
,IFNULL(SUM(VRF.KKO_NOTI_WAIT),0) AS KKO_NOTI_WAIT
FROM (
SELECT
ESI.USER_SEQ
,ESI.ENTR_NO
,IFNULL(EPR.PROD_CD,ESI.PROD_CD) AS PROD_CD
,ESU.CUST_SEQ
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),EUL.FX_LMT_AMT,0)) AS FX_LMT_AMT
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),EUL.CFWD_AMT,0)) AS CFWD_AMT
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(SYSDATE(),'%Y%m'),EUL.EXTNC_AMT,0)) AS EXTNC_AMT
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),EUL.CFWD_RSTRT_BLNC,0)) AS CFWD_RSTRT_BLNC
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),EUL.MRT_USE_AMT,0)) AS MRT_USE_AMT
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),EUL.EXTC_CHRG_AMT,0)) AS EXTC_CHRG_AMT
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),EUL.CFWD_CHRG_AMT,0)) AS CFWD_CHRG_AMT
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),EUL.EXTC_CHRG_RSRT,0)) AS EXTC_CHRG_RSRT
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),EUL.CFWD_CHRG_RSRT,0)) AS CFWD_CHRG_RSRT
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),EUL.EXTC_CHRG_BLNC,0)) AS EXTC_CHRG_BLNC
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),EUL.CFWD_CHRG_BLNC,0)) AS CFWD_CHRG_BLNC
,SUM(IF(EUL.LMT_YM = DATE_FORMAT(SYSDATE(),'%Y%m'),EUL.CFWD_AMT,0)) AS NOW_CFWD_AMT
,ESC.KKO_NOTI_COST
,ESC.SMS_COST
,ESC.LMS_COST
,ESC.MMS_COST
,ESI.SUBS_ID
,DATE_FORMAT(ESI.OPN_DT,'%Y-%m-%d') AS OPN_DT
,ESI.SUBS_STTUS_CD
FROM hubez_common.EZ_SUBS_INFO ESI LEFT JOIN hubez_admin.EZ_USER_LMT EUL ON ESI.USER_SEQ = EUL.USER_SEQ AND EUL.LMT_YM BETWEEN DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m') AND DATE_FORMAT(SYSDATE(),'%Y%m')
INNER JOIN hubez_common.EZ_SVC_USER ESU ON ESI.USER_SEQ = ESU.USER_SEQ
LEFT JOIN (SELECT
SUBS_ID,PROD_CD
FROM hubez_common.EZ_PRDCHG_RSRV
WHERE (SUBS_ID,EFCT_ST_DT) IN (
SELECT
SUBS_ID, MAX(EFCT_ST_DT)
FROM hubez_common.EZ_PRDCHG_RSRV
WHERE TRT_STTUS_CD = '02'
AND DATE_FORMAT(EFCT_ST_DT,'%Y%m') = DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m')
GROUP BY SUBS_ID
)
) EPR ON ESI.SUBS_ID = EPR.SUBS_ID
, (
SELECT
SUM(IF(ESC.SND_CH_CD = 'ALIMTALK',UCOST,0)) AS KKO_NOTI_COST
,SUM(IF(ESC.SND_CH_CD = 'SMS',UCOST,0)) AS SMS_COST
,SUM(IF(ESC.SND_CH_CD = 'LMS',UCOST,0)) AS LMS_COST
,SUM(IF(ESC.SND_CH_CD = 'MMS',UCOST,0)) AS MMS_COST
FROM hubez_common.EZ_SND_UCOST ESC
) ESC
WHERE ESI.SUBS_STTUS_CD IN ('02','03','04','99')
AND ESI.OPN_DT <![CDATA[ < ]]> DATE_FORMAT(SYSDATE(),'%Y%m01')
GROUP BY ESI.USER_SEQ
) LMT
LEFT JOIN (
SELECT
A.WEB_REQ_ID
,A.USER_SEQ
,A.REQ_CNT
,A.SNDREQ_CH_CD
,A.SMS
,A.LMS
,A.MMS
,A.SMS_GLOBAL
,A.RCS
,A.KKO_NOTI
,A.KKO_FRIEND
,A.SMS_FB
,A.LMS_FB
,A.MMS_FB
,A.SMS_FAIL
,A.LMS_FAIL
,A.MMS_FAIL
,A.SMS_GLOBAL_FAIL
,A.RCS_FAIL
,A.KKO_NOTI_FAIL
,A.KKO_FRIEND_FAIL
,IF(A.SNDREQ_CH_CD = 'SMS',(A.REQ_CNT)-(A.SMS+A.SMS_FAIL),0) AS SMS_WAIT
,IF(A.SNDREQ_CH_CD = 'LMS',(A.REQ_CNT)-(A.LMS+A.LMS_FAIL),0) AS LMS_WAIT
,IF(A.SNDREQ_CH_CD = 'MMS',(A.REQ_CNT)-(A.MMS+A.MMS_FAIL),0) AS MMS_WAIT
,IF(A.SNDREQ_CH_CD = 'ALIMTALK',(A.REQ_CNT)-(A.KKO_NOTI+A.KKO_NOTI_FAIL+KKO_NOTI_FW_FB_CNT),0) AS KKO_NOTI_WAIT
FROM (
SELECT
ESR.WEB_REQ_ID
,ESR.USER_SEQ
,ESR.REQ_CNT
,ESR.SNDREQ_CH_CD
,SUM(IF((EML.DONE_CODE = 10000 OR DRSLT_CMPLT_DT IS NULL) AND EML.REQ_PRODUCT = 'SMS', 1, 0)) AS SMS
,SUM(IF((EML.DONE_CODE = 10000 OR DRSLT_CMPLT_DT IS NULL) AND EML.REQ_PRODUCT = 'LMS', 1, 0)) AS LMS
,SUM(IF((EML.DONE_CODE = 10000 OR DRSLT_CMPLT_DT IS NULL) AND EML.REQ_PRODUCT = 'MMS', 1, 0)) AS MMS
,SUM(IF((EML.DONE_CODE = 10000 OR DRSLT_CMPLT_DT IS NULL) AND EML.REQ_PRODUCT = 'SMS_GLOBAL', 1, 0)) AS SMS_GLOBAL
,SUM(IF(((EML.DONE_CODE = 10000 AND EML.DONE_PRODUCT = 'RCS') OR DRSLT_CMPLT_DT IS NULL) AND EML.REQ_PRODUCT = 'RCS', 1, 0)) AS RCS
,SUM(IF(((EML.DONE_CODE = 10000 AND EML.DONE_PRODUCT = 'KALT1') OR DRSLT_CMPLT_DT IS NULL) AND EML.REQ_PRODUCT = 'KKO_NOTI', 1, 0)) AS KKO_NOTI
,SUM(IF(((EML.DONE_CODE = 10000 AND EML.DONE_PRODUCT = 'KALT2') OR DRSLT_CMPLT_DT IS NULL) AND EML.REQ_PRODUCT = 'KKO_FRIEND', 1, 0)) AS KKO_FRIEND
,SUM(IF(EML.DONE_CODE = 10000 AND EML.REQ_PRODUCT IN ('RCS','KKO_NOTI','KKO_FRIEND') AND EML.DONE_PRODUCT = 'SMS', 1, 0)) AS SMS_FB
,SUM(IF(EML.DONE_CODE = 10000 AND EML.REQ_PRODUCT IN ('RCS','KKO_NOTI','KKO_FRIEND') AND EML.DONE_PRODUCT = 'LMS', 1, 0)) AS LMS_FB
,SUM(IF(EML.DONE_CODE = 10000 AND EML.REQ_PRODUCT IN ('RCS','KKO_NOTI','KKO_FRIEND') AND EML.DONE_PRODUCT = 'MMS', 1, 0)) AS MMS_FB
,SUM(IF((EML.DONE_CODE = 10000 AND EML.DONE_PRODUCT != 'RCS') AND EML.REQ_PRODUCT = 'RCS', 1, 0)) AS RCS_FW_FB_CNT
,SUM(IF((EML.DONE_CODE = 10000 AND EML.DONE_PRODUCT != 'KALT1') AND EML.REQ_PRODUCT = 'KKO_NOTI', 1, 0)) AS KKO_NOTI_FW_FB_CNT
,SUM(IF((EML.DONE_CODE = 10000 AND EML.DONE_PRODUCT != 'KALT2') AND EML.REQ_PRODUCT = 'KKO_FRIEND', 1, 0)) AS KKO_FRIEND_FW_FB_CNT
,SUM(IF(EML.DONE_CODE != 10000 AND ESR.DRSLT_CMPLT_DT IS NOT NULL AND EML.REQ_PRODUCT = 'SMS', 1, 0)) AS SMS_FAIL
,SUM(IF(EML.DONE_CODE != 10000 AND ESR.DRSLT_CMPLT_DT IS NOT NULL AND EML.REQ_PRODUCT = 'LMS', 1, 0)) AS LMS_FAIL
,SUM(IF(EML.DONE_CODE != 10000 AND ESR.DRSLT_CMPLT_DT IS NOT NULL AND EML.REQ_PRODUCT = 'MMS', 1, 0)) AS MMS_FAIL
,SUM(IF(EML.DONE_CODE != 10000 AND ESR.DRSLT_CMPLT_DT IS NOT NULL AND EML.REQ_PRODUCT = 'SMS_GLOBAL', 1, 0)) AS SMS_GLOBAL_FAIL
,SUM(IF(EML.DONE_CODE != 10000 AND ESR.DRSLT_CMPLT_DT IS NOT NULL AND EML.REQ_PRODUCT = 'RCS', 1, 0)) AS RCS_FAIL
,SUM(IF(EML.DONE_CODE != 10000 AND ESR.DRSLT_CMPLT_DT IS NOT NULL AND EML.REQ_PRODUCT = 'KKO_NOTI', 1, 0)) AS KKO_NOTI_FAIL
,SUM(IF(EML.DONE_CODE != 10000 AND ESR.DRSLT_CMPLT_DT IS NOT NULL AND EML.REQ_PRODUCT = 'KKO_FRIEND', 1, 0)) AS KKO_FRIEND_FAIL
FROM hubez_admin.EZ_SNDDCT_REQ PARTITION(EZ_SNDDCT_REQ_202306) ESR LEFT OUTER JOIN hubez_send.EZ_MSG_LOG PARTITION(PT_EZ_MSG_LOG_202306) EML ON ESR.WEB_REQ_ID = EML.WEB_REQ_ID
GROUP BY ESR.WEB_REQ_ID ,ESR.USER_SEQ ,ESR.REQ_CNT
) A
) VRF ON LMT.USER_SEQ = VRF.USER_SEQ
GROUP BY LMT.USER_SEQ
) A LEFT JOIN hubez_common.EZ_CD_DTL ECD ON A.SUBS_STTUS_CD = ECD.DTL_CD AND ECD.GRP_CD = 'SUBS_STTUS_CD'
LEFT JOIN (
SELECT
A.USER_SEQ
,SUM(CASE
WHEN A.STTUS_PLAG = 'S' THEN A.EFCT_FNS_DT - A.EFCT_ST_DT + 1
WHEN A.STTUS_PLAG = 'P' THEN -1
WHEN A.STTUS_PLAG = 'E' THEN 0
END) AS USE_DAY
FROM (
SELECT
ESI.CUST_SEQ
,ESI.USER_SEQ
,ESI.SUBS_ID
,IF(DATE_FORMAT(ESH.EFCT_ST_DT,'%Y%m') != DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m'),'01',DATE_FORMAT(ESH.EFCT_ST_DT,'%d')) AS EFCT_ST_DT
,IF(ESH.EFCT_FNS_DT <![CDATA[ > ]]> LAST_DAY(DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m%d')) ,DATE_FORMAT(LAST_DAY(DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m%d')),'%d'),DATE_FORMAT(ESH.EFCT_FNS_DT,'%d')) AS EFCT_FNS_DT
,(CASE WHEN ESH.SUBS_STTUS_CD IN ('02') THEN 'S' WHEN ESH.SUBS_STTUS_CD IN ('03','04') THEN 'P' ELSE 'E' END) AS STTUS_PLAG
,DATE_FORMAT(LAST_DAY(DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m%d')),'%d') AS LAST_DT
FROM hubez_common.EZ_SUBS_INFO ESI, hubez_common.EZ_SBSCST_HST ESH
WHERE ESI.SUBS_ID = ESH.SUBS_ID
AND (DATE_FORMAT(EFCT_ST_DT,'%Y%m%d') <![CDATA[ < ]]> DATE_FORMAT(SYSDATE(),'%Y%m01')
AND DATE_FORMAT(EFCT_FNS_DT,'%Y%m%d') <![CDATA[ > ]]> DATE_FORMAT(DATE_ADD(SYSDATE(),INTERVAL -1 MONTH),'%Y%m01'))
AND ESH.SUBS_STTUS_CD NOT IN ('00','01','98')
) A
GROUP BY A.USER_SEQ
) USETB ON A.USER_SEQ = USETB.USER_SEQ
,hubez_common.EZ_CUST_INFO ECI, hubez_common.EZ_PROD_INFO EPI
WHERE A.CUST_SEQ = ECI.CUST_SEQ
AND A.PROD_CD = EPI.PROD_CD
AND A.CUST_SEQ NOT IN ('100000001','100000164')
) A
) A
ORDER BY ENTR_NO ASC
</select>
</mapper> </mapper>