Oracle必须死之奇怪的ORA-06502错误

  作为熟练.Net码农以及非熟练Oracle用户很多时候Oracle总给我一种这货就是存心恶心我们的感觉。

  虽然不得不承认Oracle是个很(an)好(gui)的产品,但是总有那么好几下被恶心到了。比如说屎一样的驱动,还比如说今天遇到的奇怪错误。

  事情是这样子的:当在数据库中增加了新的资料后,系统中执行如下脚本时总是报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来处理就好了。

  最后说一句:Oracle必须死

你可能感兴趣的:(oracle)