如果您希望它是可讀文本,則可以使用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」);'。 –