输入的SQL文本本身太长,单行超过2500个字符,与数据库内部的数据无关,是对SQLPlus具有命令行大小限制。
此外单条SQL语句长度不能超4000,但是使用过程无限制。
(一)升级到12.2(?)客户端。在12.2上,客户端最多允许4999个字符。如果Oracle最终承认2499还不够,为什么他们只将限制提高到4999?-----仍然不是解决问题一劳永逸的方式
(二)添加换行符。将结果分成多行。如果使用Windows,请确保同时使用回车符和换行符-chr(13)||chr(10)。
(三)使用其他程序。许多程序都有类似SQL* Plus的选项。通常,我建议不要使用SQL* Plus克隆。SQL* Plus的主要优点是它是一个简单的工具,并且在任何地方都可以使用。没有SQL* Plus克隆是完全兼容的,如果在克隆上运行SQL* Plus脚本,许多程序将中断。
当CLOB大对象的字段值超过4000时,并且直接Insert或update时,会报如下的错:
ORA-22835: 缓冲区对于 CLOB 到 CHAR 转换或 BLOB 到 RAW 转换而言太小 (实际: 5679, 最大: 4000)
ORA-06512: 在 line 111
ORA-01704: 文字字符串过长
可用下面的方法解决:
declare
v_clob clob:='大对象字符串,超过4000.....';
begin
insert into erm_license values(111,5,v_clob);
end;
/
commit;
update也可以用同样的方法解决。
原因:CLOB的所有内容在一行上,一行超过2499就报错了,解决的办法是将原来的一行拆成N行。
例子:
declare
v_clob clob:='大对象字符串,超过4000.....大对象字符串,一行超2499.....';
begin
insert into erm_license values(111,5,v_clob);
end;
/
commit;
假设上面的v_clob是一行,且长度超4000.直接按上面的方法会报错SP2-0027
解决方案:
使用’||'将一行拆分:
declare
v_clob clob:='大对象字符串,超过4000......'||
'大对象字符串,一行超2499.....';
begin
insert into erm_license values(111,5,v_clob);
end;
/
commit;