Oracle ORA-06502错误解决

select getmaterialinfo() from dual

  说明下,getmaterialinfo是个返回varchar2的function。好吧,看起来是function里面变量的大小有问题,果断调试之。

  不过当执行下列调试语句时,奇迹发生了:

DECLARE
  struserid varchar2(200);
  v_Return VARCHAR2(10000);
begin
  STRUSERID := '10000';

  v_return := getmaterialinfo(
    STRUSERID=>STRUSERID
  );

end;

  是的,什么都没有发生!!!!就这么正常结束了!!!!!一个奇迹由于什么都没有发生而发生了,这不是个奇迹又能是什么?

  好吧,神神叨叨的就跳过吧。还是简单说下结论:

  返回的字符串长度超过4000,而默认缓冲区大小是4000,于是Oracle果断报了个错(不理解为什么返回类型设置了是varchar2(5000)了还需要纠结返回长度……求解释?),抛出个看错误输出的描述完全猜不到的错误来。

  参考解决方法 http://stackoverflow.com/questions/3790379/how-to-query-a-clob-column-in-oracle,简单说就是当作CLOB来处理就好了。

猜你喜欢

转载自www.linuxidc.com/Linux/2016-04/129803.htm