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属性的数据,这里就不列出转换方法

  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值