Về cơ bản, bạn đang cố gắng lưu trữ một chuỗi biểu thị ngày trong trường dấu thời gian. Nếu bạn thay thế:
TO_CHAR(TS, 'DD-MON-YYYY HH AM')
bởi
TRUNC(TS, 'hh24')
ở cả 4 nơi, nó sẽ hoạt động.
INSERT INTO ENROLLMENTS (DATE,PARTNER_NAME,ENROLLMENTS)
SELECT TRUNC(TS, 'hh24') AS DATE, mrch_bnft_cd, COUNT(*)
FROM ENROLLMENTS
WHERE TS > trunc(sysdate-1/24, 'HH') + 5/24
AND TS < trunc(sysdate, 'HH') + 5/24
GROUP BY TRUNC(TS, 'hh24'), mrch
ORDER BY TRUNC(TS, 'hh24'), mrch_bnft