Vous pouvez convertir votre valeur LONG RAW en un BLOB dans un bloc PL/SQL, puis l'encoder en base64 :
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;
/
Bien sûr, recommande fortement de convertir les colonnes LONG RAW aux colonnes binaires LOB (BLOB) ; stocker encore des données sous forme brute LONG ou LONG semble plutôt désuet maintenant.