2011年记
目的:
遇到这种情况,mysql to oracle时 text类型转到oracle自动变为BLOB,但这些字段只需要CLOB.所以打算把BLOB转为CLOB。(在sqlplu或plsql中完成)
解决办法
例:表gw_gift 字段description BLOB
1、增加字段description1 CLOB
2、把BLOB列数据写入CLOB
update gw_gift p set p.description1=utl_raw.cast_to_varchar2(p.description) where DBMS_LOB.GETLENGTH(DESCRIPTION)>2000;
commit;
注:utl_raw.cast_to_varchar2() 转换BLOB为RAW,再转入CLOB
DBMS_LOB.GETLENGTH()取得BLOB内容的长度。因为BLOB转RAW时超过2000会报“ORA-22835:缓冲区对于BLOB到RAW转换而言太小(实际:4366,最大2000)”