Project

General

Profile

VOC support #2171 » #2171-Check-rate-allotment.sql

Daniel Do, 11/03/2025 05:00 AM

 
1
-- Define date ranges
2
SET @NOWADAY = NOW();
3
SET @F_R1 = DATE(@NOWADAY);
4
SET @T_R1 = DATE_ADD(@F_R1, INTERVAL 30 DAY);
5
SET @F_R3 = DATE_ADD(@F_R1, INTERVAL 31 DAY);
6
SET @T_R3 = DATE_ADD(@F_R1, INTERVAL 60 DAY);
7
SET @F_R4 = DATE_ADD(@F_R1, INTERVAL 61 DAY);
8
SET @T_R4 = DATE_ADD(@F_R1, INTERVAL 90 DAY);
9
 
10
WITH
11
-- 1 Daily rate summary by hotel + room type
12
VRDP_SUM AS (  
13
    SELECT
14
        VVHC.HOTEL_CODE,
15
        VVRP.VENDOR_ROOM_TYPE_SEQ,
16
         SUM(CASE WHEN VRDP.VENDOR_NET_AMOUNT > 0 AND VRDP.SALES_STOP_YN = 'N' THEN 1 ELSE 0 END) AS CNT
17
    FROM VD_VENDOR_ROOM_DAILY_PRICE VRDP
18
    INNER JOIN VD_VENDOR_ROOM_PLAN VVRP ON VVRP.ROOM_PLAN_SEQ = VRDP.ROOM_PLAN_SEQ AND VVRP.SALES_STOP_YN = 'N'
19
    INNER JOIN VD_VENDOR_HOTEL_CONTRACT VVHC ON VVRP.HOTEL_CONTRACT_SEQ = VVHC.HOTEL_CONTRACT_SEQ AND VVHC.CONTRACT_STATUS_CODE = 'A'
20
    -- WHERE VRDP.APPLIED_DATE BETWEEN @F_R1 AND @T_R1 -- 0-30
21
    -- WHERE VRDP.APPLIED_DATE BETWEEN @F_R3 AND @T_R3 -- 31-60
22
    WHERE VRDP.APPLIED_DATE BETWEEN @F_R4 AND @T_R4    -- 61-90 
23
    GROUP BY VRDP.HOTEL_CODE, VRDP.VENDOR_ROOM_TYPE_SEQ
24
    
25
),
26

    
27
-- ⃣ Allotment summary by room type
28
VRA_SUM AS (
29
    SELECT
30
        VRA.VENDOR_ROOM_TYPE_SEQ,
31
        SUM(CASE WHEN VRA.LEFT_COUNT_SUM > 0 AND VRA.SALES_STOP_YN = 'N' THEN 1 ELSE 0 END) AS CNT
32
    FROM VD_VENDOR_ROOM_ALLOTMENT VRA
33
    INNER JOIN VD_VENDOR_ROOM_TYPE VRT ON VRA.VENDOR_ROOM_TYPE_SEQ = VRT.VENDOR_ROOM_TYPE_SEQ AND VRT.SALES_STOP_YN = 'N'
34
    INNER JOIN VD_VENDOR_HOTEL_CONTRACT VVHC ON VVHC.HOTEL_CODE = VRT.HOTEL_CODE AND VVHC.CONTRACT_STATUS_CODE = 'A'
35
    -- WHERE VRA.APPLIED_DATE BETWEEN @F_R1 AND @T_R1 -- 0-30
36
    -- WHERE VRA.APPLIED_DATE BETWEEN @F_R3 AND @T_R3 -- 31-60
37
    WHERE VRA.APPLIED_DATE BETWEEN @F_R4 AND @T_R4    -- 61-90
38
    GROUP BY VRA.VENDOR_ROOM_TYPE_SEQ
39
),
40

    
41
HOTEL_INFO AS (
42
    SELECT DISTINCT
43
        HM.COUNTRY_CODE,
44
        BCC.COUNTRY_NAME_EN AS COUNTRY_NAME,
45
        HM.HOTEL_CODE,
46
        IFNULL(HM.LEGACY_HOTEL_CODE, VHC.LEGACY_HOTEL_CODE) AS LEGACY_HOTEL_CODE,
47
        HM.HOTEL_NAME_EN AS HOTEL_NAME,
48
        HM.REGION_CODE,
49
        BRC.REGION_NAME_EN AS REGION_NAME,
50
        HM.REGISTER_STATUS_CODE,
51
        DC.DETAIL_CODE_NAME_EN AS HOTEL_STATUS,
52
        HM.ADDRESS_EN,
53
        HM.PHONE_NO,
54
        HM.STAR_RATING,
55
        VHC.CONTRACT_STATUS_CODE,
56
        VRT.VENDOR_ROOM_TYPE_SEQ
57
    FROM HO_HOTEL_MASTER HM
58
    INNER JOIN VD_VENDOR_HOTEL_CONTRACT VHC ON HM.HOTEL_CODE = VHC.HOTEL_CODE AND VHC.CONTRACT_STATUS_CODE = 'A'
59
    INNER JOIN VD_VENDOR_ROOM_TYPE VRT ON HM.HOTEL_CODE = VRT.HOTEL_CODE AND VRT.SALES_STOP_YN = 'N'
60
    LEFT JOIN BS_COUNTRY_CODE BCC ON HM.COUNTRY_CODE = BCC.COUNTRY_CODE
61
    LEFT JOIN BS_REGION_CODE BRC ON BRC.REGION_CODE = HM.REGION_CODE
62
    LEFT JOIN BS_DETAIL_CODE DC ON DC.MASTER_CODE = 'BS018' AND HM.REGISTER_STATUS_CODE = DC.DETAIL_CODE
63
)
64
 
65
SELECT 
66
    HI.COUNTRY_CODE,
67
    HI.COUNTRY_NAME,
68
    HI.REGION_NAME,
69
    HI.HOTEL_CODE,    
70
    HI.HOTEL_NAME,
71
    HI.LEGACY_HOTEL_CODE,
72
    HI.HOTEL_STATUS,
73
    CASE 
74
        WHEN SUM(CASE WHEN (IFNULL(RDP.CNT,0) > 10 OR IFNULL(RA.CNT,0) > 10) THEN 0 ELSE 1 END) > 0
75
        THEN 'No bookable'
76
        ELSE 'Bookable'
77
    END AS Bookable
78
FROM HOTEL_INFO HI
79
LEFT JOIN VRDP_SUM RDP ON RDP.HOTEL_CODE = HI.HOTEL_CODE AND RDP.VENDOR_ROOM_TYPE_SEQ = HI.VENDOR_ROOM_TYPE_SEQ
80
LEFT JOIN VRA_SUM RA ON RA.VENDOR_ROOM_TYPE_SEQ = HI.VENDOR_ROOM_TYPE_SEQ 
81
GROUP BY 
82
    HI.COUNTRY_CODE,
83
    HI.COUNTRY_NAME,
84
    HI.REGION_NAME,
85
    HI.HOTEL_CODE,    
86
    HI.HOTEL_NAME,
87
    HI.LEGACY_HOTEL_CODE,
88
    HI.HOTEL_STATUS
89
ORDER BY 
90
    HI.COUNTRY_CODE, 
91
    HI.HOTEL_CODE;
(2-2/2)
Add picture from clipboard (Maximum size: 50 MB)