Мы не можем ограничить тип данных при указании параметров в хранимых процедурах.То есть, просто используйте VARCHAR2 вместо VARCHAR2 (50).
Просто чтобы доказать, что я воспроизвожу вашу проблему ...
SQL> CREATE OR REPLACE FUNCTION lm_date_convert (lm_date_in IN VARCHAR2(50))
2 RETURN DATE DETERMINISTIC IS
3 BEGIN
4 RETURN(TO_DATE(REGEXP_REPLACE(lm_date_in, '([[:digit:]]{2})[-/.]*([[:digit:]]{2})[-/.]*([[:digit:]]{4})','\3-\1-\2'), 'YYYY-MM-DD'));
5 END;
6 /
Warning: Function created with compilation errors.
SQL> sho err
Errors for FUNCTION LM_DATE_CONVERT:
LINE/COL ERROR
-------- -----------------------------------------------------------------
1/49 PLS-00103: Encountered the symbol "(" when expecting one of the
following:
:= . ) , @ % default character
The symbol ":=" was substituted for "(" to continue.
SQL>
Теперь, чтобы исправить это:
SQL> ed
Wrote file afiedt.buf
1 CREATE OR REPLACE FUNCTION lm_date_convert (lm_date_in IN VARCHAR2)
2 RETURN DATE DETERMINISTIC IS
3 BEGIN
4 RETURN(TO_DATE(REGEXP_REPLACE(lm_date_in, '([[:digit:]]{2})[-/.]*([[:digit:]]{2})[-/.]*([[:digit:]]{4})','\3-\1-\2'), 'YYYY-MM-DD'));
5* END;
SQL> r
1 CREATE OR REPLACE FUNCTION lm_date_convert (lm_date_in IN VARCHAR2)
2 RETURN DATE DETERMINISTIC IS
3 BEGIN
4 RETURN(TO_DATE(REGEXP_REPLACE(lm_date_in, '([[:digit:]]{2})[-/.]*([[:digit:]]{2})[-/.]*([[:digit:]]{4})','\3-\1-\2'), 'YYYY-MM-DD'));
5* END;
Function created.
SQL>
"Если вы действительно хотите VARCHAR2 (50), тогда объявите тип VARCHAR2 (50) и используйте тип."
Объявление типа SQL длянавязывание размеров - это немного излишне.Мы можем объявить SUBTYPE в PL / SQL, но их размеры фактически не применяются в сигнатурах хранимых процедур.Однако есть обходные пути, поскольку я обсуждаю в этой другой теме .
Кроме того, почему вы используете Regex для решения этой проблемы?Или, скорее, какую проблему вы пытаетесь решить, которая не может быть решена с помощью TO_CHAR и TO_DATE?Оракул довольно простителен с форматными масками.