ORA-06575: Пакет или функция FUNC_GETCREATEDTIME находится в недопустимом состоянии - PullRequest
0 голосов
/ 07 мая 2020

Я впервые попытался создать такую ​​функцию:

create or replace function func_getcreatedtime(p_createdtime varchar2)
return varchar2 as
    formatted_time varchar2(1000) := '';
begin
    select case formatted_time 
    when TO_CHAR(sysdate, 'YYYY') = TO_CHAR(p_createdtime, 'YYYY') 
    then TO_CHAR(p_createdtime, 'Mon DD') || ' at ' || TO_CHAR(p_createdtime, 'HH24:MI') createdtime
    else TO_CHAR(p_createdtime, 'Mon DD, YYYY') || ' at ' || TO_CHAR(p_createdtime, 'HH24:MI') createdtime,
    end
from dual;

return formatted_time;
end;

и попытался вызвать эту функцию следующим образом:

select t.comments, t.createdtime, func_getcreatedtime(t.createdtime) from postcomment t;

, но она показывает эту ошибку:

ORA-06575: Пакет или функция FUNC_GETCREATEDTIME находится в недопустимом состоянии

t.createdtime находится в формате 30-APR-20 06.59.59.546000 PM, я хочу отформатировать это datetime.

Если sysdate и t.createdtime имеют один и тот же год, я хочу отформатировать его до Apr 30 at 06:59

Если sysdate и t.createdtime имеют другой год, я хочу отформатировать его до Apr 30, 2020 at 06:59

Ответы [ 2 ]

1 голос
/ 07 мая 2020

Создайте функцию, как показано ниже, используя SELECT INTO formatted_time

    create or replace function func_getcreatedtime(p_createdtime varchar2)
    return varchar2 as
        formatted_time varchar2(1000) := '';
        format_date timestamp; 
    begin
        format_date:=to_timestamp(p_createdtime,'DD-MON-YY HH.MI.SS.FF PM');

        select case  
        when TO_CHAR(sysdate, 'YYYY') = TO_CHAR(format_date, 'YYYY') 
        then TO_CHAR(format_date, 'Mon DD') || ' at ' || TO_CHAR(format_date, 'HH24:MI') 
        else TO_CHAR(format_date, 'Mon DD, YYYY') || ' at ' || TO_CHAR(format_date, 'HH24:MI') 
        end as created_time
        INTO formatted_time
    from dual;

    return formatted_time;
    end;
1 голос
/ 07 мая 2020

Эта ошибка означает, что либо функция имеет ошибки, либо что-то, что вызывает функции, было изменено, и база данных сделала функцию недействительной, чтобы принудительно скомпилировать ее.

В этом случае ваша функция имеет ошибки. Вы можете просмотреть ошибки, выполнив

SELECT *
  FROM USER_ERRORS
  WHERE NAME = 'FUNC_GETCREATEDTIME`

, где вы найдете следующее:

FUNC_GETCREATEDTIME FUNCTION    1   6   35  PL/SQL: ORA-00905: missing keyword  ERROR   0
FUNC_GETCREATEDTIME FUNCTION    2   5   5   PL/SQL: SQL Statement ignored   ERROR   0
FUNC_GETCREATEDTIME FUNCTION    3   13  3   PLS-00103: Encountered the symbol "end-of-file" when expecting one of the following:

   ; <an identifier> <a double-quoted delimited-identifier>
   current delete exists prior <a single-quoted SQL string>
The symbol ";" was substituted for "end-of-file" to continue.
ERROR   103

См. Эту db <> fiddle

...