在Oracle中使用BLOB对象

时间:2012-10-09 13:57:55

标签: oracle base64 converter

我有一个像这样的SQL语句 -

select utl_encode.utl_encode.base64_encode(IMAGE1) 
from IPHONE.accidentreports 
where "key" = 66

但是当我运行它时,我得到了这个错误 -

ORA-00904: "UTL_ENCODE"."UTL_ENCODE"."BASE64_ENCODE": invalid identifier
00904. 00000 -  "%s: invalid identifier"
*Cause:    
*Action:
Error at Line: 2 Column: 8

我想将BLOB对象转换为BASE64。怎么可能呢?

2 个答案:

答案 0 :(得分:3)

由于UTL_ENCODE.BASE64_ENCODE函数适用于RAW,因此它适用于PL/SQL中最多32767字节或SQL中4000字节的BLOB。

如果您的图像较大,则必须编写自己的功能。这是一个例子:

CREATE OR REPLACE FUNCTION base64_encode_blob (p BLOB) RETURN BLOB IS
   l_raw    RAW(24573);
   l_base64 RAW(32767);
   l_result BLOB;
   l_offset NUMBER := 1;
   l_amount NUMBER := 24573;
BEGIN
   DBMS_LOB.createtemporary(l_result, FALSE);
   DBMS_LOB.open(l_result, DBMS_LOB.lob_readwrite);
   LOOP
      DBMS_LOB.read(p, l_amount, l_offset, l_raw);
      l_offset := l_offset + l_amount;
      l_base64 := utl_encode.base64_encode(l_raw);
      DBMS_LOB.writeappend(l_result, utl_raw.length(l_base64), l_base64);
   END LOOP;
EXCEPTION
   WHEN NO_DATA_FOUND THEN
      RETURN l_result;
END;
/

答案 1 :(得分:0)

首先UTL_ENCODE.BASE64_ENCODE适用于RAW值的二进制表示,函数如下:

UTL_ENCODE.BASE64_ENCODE (
   r  IN RAW) 
RETURN RAW;

因此,考虑IMAGE1RAW类型:

SELECT UTL_ENCODE.BASE64_ENCODE(CAST(IMAGE1 AS RAW))  --if IMAGE1 is LOB
  FROM IPHONE.accidentreports 
 WHERE "key" = 66;

更多关于CAST here