第一句子网 - 唯美句子、句子迷、好句子大全
第一句子网 > oracle blob 转 varchar2 oracle varchar2与clob blob互转

oracle blob 转 varchar2 oracle varchar2与clob blob互转

时间:2023-10-30 07:50:28

相关推荐

oracle blob 转 varchar2 oracle varchar2与clob blob互转

BLOB和CLOB都是大字段类型,BLOB是按二进制来存储的,而CLOB是可以直接存储文字的。其实两个是可以互换的的,或者可以直接用LOB字段代替这两个。但是为了更好的管理ORACLE数据库,通常像图片、文件、音乐等信息就用BLOB字段来存储,先将文件转为二进制再存储进去。而像文章或者是较长的文字,就用CLOB存储,这样对以后的查询更新存储等操作都提供很大的方便。

Blob转varchar2:

长度小于2000的:

Convert(Utl_Raw.Cast_To_Varchar2(A.Photodata), 'utf8', 'zhs16gbk')

长度大于2000:

Create Or Replace Function Blob_To_Varchar (Blob_In In Blob) Return Varchar2

Is

V_Varchar Varchar2(4000);

V_Start Pls_Integer := 1;

V_Buffer Pls_Integer := 4000;

Begin

If Dbms_Lob.Getlength(Blob_In) Is Null Then

Return '';

End If;

For I In 1..Ceil(Dbms_Lob.Getlength(Blob_In) / V_Buffer) Loop

--当转换出来的字符串乱码时,可尝试用注释掉的函数

--V_Varchar := Utl_Raw.Cast_To_Varchar2(Utl_Raw.Convert(Dbms_Lob.Substr(Blob_In, V_Buffer, V_Start),'SIMPLIFIED CHINESE_CHINA.ZHS16GBK', 'AMERICAN_THE NETHERLANDS.UTF8'));

V_Varchar := Utl_Raw.Cast_To_Varchar2(Dbms_Lob.Substr(Blob_In, V_Buffer, V_Start));

V_Start := V_Start + V_Buffer;

End Loop;

Return V_Varchar;

End Blob_To_Varchar;

varchar2Blob 注意varchar2的最大长度是4000,超过的话转换会出现问题,只出现最后面的部分。中文还没尝试过。

CREATE OR REPLACE FUNCTION V2B(l_var IN varchar2) RETURN BLOB IS

c_clob CLOB := to_clob(l_var);

b_blob BLOB;

b_len number := dbms_lob.getlength(c_clob);

b_offset NUMBER := 1;

c_offset NUMBER := 1;

c_amount INTEGER := DBMS_LOB.lobmaxsize;

b_csid NUMBER := DBMS_LOB.default_csid;

lang_ctx INTEGER := DBMS_LOB.default_lang_ctx;

warning INTEGER;

BEGIN

if b_len > 0 then

DBMS_LOB.createtemporary(b_blob, TRUE);

DBMS_LOB.OPEN(b_blob, DBMS_LOB.lob_readwrite);

DBMS_LOB.convertToBlob(b_blob,

c_clob,

c_amount,

b_offset,

c_offset,

b_csid,

lang_ctx,

warning);

else

select empty_blob() into b_blob from dual;

end if;

RETURN b_blob;

END V2B;

CLOB转Varchar2 to_char(substr(mw.context_,1,1000)) 这个是oracle自带的

CLOB的列可以直接放varchar属性的数据,这里就不列出转换方法

本内容不代表本网观点和政治立场,如有侵犯你的权益请联系我们处理。
网友评论
网友评论仅供其表达个人看法,并不表明网站立场。