Sie können Ihren LONG RAW-Wert in einen BLOB in einem PL/SQL-Block konvertieren und diesen dann base64-kodieren:
CREATE OR REPLACE FUNCTION to_base64 (
vcodem IN FOEMP.COD_EMPR%TYPE,
vcodempl IN FOEMP.COD_EMPL%TYPE)
RETURN VARCHAR2
IS
l_blob BLOB;
l_long_raw LONG RAW;
BEGIN
SELECT fot_empl INTO l_long_raw
FROM foemp
WHERE COD_EMPL = vcodempl AND COD_EMPR = vcodem;
l_blob := TO_BLOB(l_long_raw);
RETURN UTL_RAW.cast_to_varchar2 (UTL_ENCODE.base64_encode (l_blob));
END;
/
Natürlich empfiehlt dringend, dass Sie LONG RAW-Spalten konvertieren in binäre LOB (BLOB)-Spalten ; Daten immer noch als LONG oder LONG raw zu speichern scheint jetzt ziemlich antiquiert.