PLSQLDeveloper中调试含clob字段的存储过程中出现 ORA-03127: 在活动操作结束之前不允许进行操作

PLSQLDeveloper中调试含clob字段的存储过程中出现 ORA-03127: 在活动操作结束之前不允许进行操作,百思不得其解。

后查看英文书籍中clob讲解后突然觉悟,clob实际就是指针,调试中出现ora03127,但c#调用时未出现,证明存储过程中clob的用法是正确的,出现错误的原因是未释放clob的空间。


在测试窗口最后加上dbms_lob.freetemporary(:strlogclob);即可。

存储过程代码如下

procedure  proc_update(
                                       strLogClob out clob,
                                       retValue out int
                                       )

原先出现ora03127错误的测试代码如下:

declare
  -- Non-scalar parameters require additional processing 
  
begin
  
  
  -- Call the procedure
  proc_update(strlogclob => :strlogclob,
              retvalue => :retvalue);
  
end;


改正后的测试代码如下:

declare
  -- Non-scalar parameters require additional processing 
  
begin  
  
  -- Call the procedure
  proc_update(strlogclob => :strlogclob,
              retvalue => :retvalue);
  dbms_output.put_line('length(clob):'||dbms_lob.getlength(:strlogclob));
  --dbms_output.put_line('clob:'||:strlogclob);
  --注意,测试时要释放clob,但在C#端调用时,要由C#的调用方自行释放
  dbms_lob.freetemporary(:strlogclob);
end;


结束,调试过程清静了,再也没有ora03127。

  • 0
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值