Oracle: nie ważny miesiąc

Mam tabelę z następującymi polami:

Raporty (nazwa tabeli) Rep_Date (data) Rep_Time (data)

Pole Rep_Time ma wartości takie jak '01 / 01/1753 07:30:00 ', tzn. Część czasu jest istotna. Napisałem następujące zapytanie:

select Reports.pid, MaxDate from Reports
INNER JOIN (
    select pid, max(TO_DATE(TO_CHAR(REP_DATE, 'DD/MM/YYYY')
        || TO_CHAR(REP_TIME, 'HH24:MI:SS'), 'DD/MM/YYYY HH24:MI:SS')) As MaxDate
    from reports
    group by pid
) ReportMaxDate
on Reports.PID = ReportMaxDate.PID
AND To_Date(To_Char(MaxDate, 'DD/MM/YYYY')) = REP_DATE
WHERE REPORTS.PID=61

Pochodząca z tabeli część zapytania działa, ale po uruchomieniu całego zapytania pojawia się błąd: „nie jest prawidłowy miesiąc”. Dlaczego to?

Aby pomóc w debugowaniu tego; jeśli uruchomię następujące zapytanie:

select rep_date, rep_time from reports where pid=61 and rownum=1

Dostaję:

Rep_Date = 01/04/2009
Rep_Time = 01/01/1753 13:00:00

AKTUALIZACJA 15:58 Teraz mogę wykonać następujące zapytanie:

select Reports.pid, MaxDate from Reports
INNER JOIN (
    select pid, max(TO_DATE(TO_CHAR(REP_DATE, 'DD/MM/YYYY')
        || TO_CHAR(REP_TIME, 'HH24:MI:SS'), 'DD/MM/YYYY HH24:MI:SS')) As MaxDate
    from reports group by pid
) ReportMaxDate
on Reports.PID = ReportMaxDate.PID
AND to_date(to_char(maxdate,'MM/DD/YYYY'),'MM/DD/YYYY') = REP_DATE
WHERE REPORTS.PID=61

Muszę jednak dodać jeszcze jedną instrukcję doWHERE klauzula porównująca część czasu MaxDate z rep_time:to_date(to_char(maxdate,'MM/DD/YYYY'),'MM/DD/YYYY') = REP_DATE nie działa.

questionAnswers(2)

yourAnswerToTheQuestion