前言:
现在小伙伴们对“oracle反转函数乱码”大体比较注重,大家都需要分析一些“oracle反转函数乱码”的相关内容。那么小编也在网上网罗了一些有关“oracle反转函数乱码””的相关内容,希望看官们能喜欢,兄弟们快快来了解一下吧!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转Varchar2to_char(substr(mw.context_,1,1000))这个是oracle自带的
CLOB的列可以直接放varchar属性的数据,这里就不列出转换方法
本文由博客一文多发平台 OpenWrite 发布!
版权声明:
本站文章均来自互联网搜集,如有侵犯您的权益,请联系我们删除,谢谢。
标签: #oracle反转函数乱码