如果您希望它是可读文本,则可以使用utl_encode
软件包中提供的函数将其转换。
utl_encode.base64_decode()
一些代码来源elsewhere使用它:
FUNCTION get_blob_from_base64_string (p_clob CLOB)
RETURN BLOB
IS
l_chunk BLOB; --Chunks of decoded blob that'll be appended
l_result BLOB; --Final blob result to be returned
l_rawout RAW (32767); --Decoded raw data from first pass decode
l_rawin RAW (32767); --Encoded raw data chunk
l_amt NUMBER DEFAULT 7700; --Default length of data to decode
l_offset NUMBER DEFAULT 1; --Default Offset of data to decode
l_tempvarchar VARCHAR2 (32767);
BEGIN
BEGIN
DBMS_LOB.createtemporary (l_result, FALSE, DBMS_LOB.CALL);
DBMS_LOB.createtemporary (l_chunk, FALSE, DBMS_LOB.CALL);
LOOP
DBMS_LOB.READ (p_clob, l_amt, l_offset, l_tempvarchar);
l_offset := l_amt + l_offset;
l_rawin := UTL_RAW.cast_to_raw (l_tempvarchar);
l_rawout := UTL_ENCODE.base64_decode (l_rawin);
l_chunk := to_blob (l_rawout);
DBMS_LOB.append (l_result, l_chunk);
END LOOP;
EXCEPTION
WHEN NO_DATA_FOUND
THEN
NULL;
END;
来源是Oracle论坛上张贴的base64 解码CLOB(> 32K)
为什么要将结果字节[]转换为字符串?你确定它是一个字符串?还有UTF8?如果是这样,为什么将它存储为BLOB? – m0skit0
如果你将它存储为一个blob,你为什么会打扰base-64编码呢?在我看来,你需要更仔细地调查真实情况。 –
也许你的意思是'返回新的字符串(bdata,“EUC_KR”);'。 –