DECLARE
YEAR NUMBER;
BEGIN
DELETE FROM HISTORY_SUM;
INSERT INTO HISTORY_SUM (YEAR)
Select DISTINCT(TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY'))) as YEAR from HISTORY
ORDER BY YEAR;
FOR x IN (Select * from HISTORY_SUM) LOOP
UPDATE HISTORY_SUM
SET JAN = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 1)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET FEB = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 2)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET MAR = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 3)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET APR = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 4)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET MAY = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 5)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET JUN = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 6)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET JUL = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 7)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET AUG = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 8)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET SEP = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 9)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET OCT = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 10)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET NOV = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 11)
WHERE YEAR = x.YEAR;
UPDATE HISTORY_SUM
SET DEC = (Select SUM(TOTAL_$) from HISTORY c
WHERE TO_NUMBER(TO_CHAR(VISIT_DATE, 'YYYY')) = YEAR AND TO_NUMBER(TO_CHAR(VISIT_DATE, 'MM')) = 12)
WHERE YEAR = x.YEAR;
END LOOP;
COMMIT;
END;
No. | Subject | Author | Date | Views |
---|---|---|---|---|
126 | LAST DAY SQL | admin | 2024.01.19 | 65 |
125 | Null Display Value | admin | 2024.01.10 | 68 |
124 | 영수증 2023 | admin | 2024.01.04 | 135 |
123 | Column Data 일괄 추가 | admin | 2023.11.24 | 85 |
122 | Using SQL*Plus to Unlock and Change Passwords | admin | 2023.06.04 | 100 |
121 | Reversing Require HTTPS | admin | 2023.06.04 | 83 |
120 | ipconfig | admin | 2023.06.03 | 66 |
119 | 127.0.0.1:8080/apex/ | admin | 2023.06.03 | 82 |
118 | CHANGE TABLE NAME | admin | 2023.05.31 | 57 |
117 | DATE -> DAY CONVERT SQL | admin | 2023.05.25 | 37 |
116 | YEAR EXPRESSIONS | admin | 2023.05.25 | 34 |
115 | GRAPH (BAR) SQL SAMPLE | admin | 2023.05.25 | 38 |
» | Monthly SUM | admin | 2023.05.22 | 36 |
113 | INNER JOIN | admin | 2023.05.19 | 36 |
112 | LOOP TABLE UPDATE | admin | 2023.05.19 | 49 |
111 | Global pages | admin | 2023.05.09 | 40 |
110 | ORACLE COLLECTION | admin | 2023.05.08 | 37 |
109 | FINAL TEST | admin | 2023.05.08 | 43 |
108 | GitHub.com/Oracle/APEX. | admin | 2023.05.04 | 39 |
107 | TEST | admin | 2023.05.03 | 35 |