delphi ora-06502 pl sql 数字或值错误 字符串缓冲区太小

网上说的大多数其它语言的修正方法,没有DELPHI版本的修正方法,今刚好也碰到这个问题,就写一下解决方法吧。

oracle里面定义的PK_PRJSTATUS_CONVERT.projectstatusconvert(projectid1 varchar2, projectid2 varchar2, converttype int,msg out varchar2)

msg为返回给客户端的信息。

delphi code:

function ConvertProjectStatus(const ASourceProjectID, ADestProjectID :string; const AType :Integer):string;
begin
DM.TB_Temp.Close;
DM.TB_Temp.SQL.Clear;
DM.TB_Temp.SQL.Text := ' begin PK_PRJSTATUS_CONVERT.projectstatusconvert(:ASourceProjectID, :ADestProjectID, :AType, :LResult); end; ';
  //省略部分语句
DM.TB_Temp.Parameters.ParamByName('LResult').Direction := pdOutput;
DM.TB_Temp.Parameters.ParamByName('LResult').DataType := ftString;
DM.TB_Temp.Parameters.ParamByName('LResult').Value := vaNull;
  DM.TB_Temp.Parameters.ParamByName('LResult').Size := 3000; //设置接收大小,则不会出现ora-06502错误
DM.TB_Temp.ExecSQL;
Result := VarToStr( DM.TB_Temp.Parameters.ParamByName('LResult').Value );
end;

在ADODB中TParameter中的Size默认大小为0,所以返回字段最好设置一下大小。


发表地:广州 日期:2011.07.02


  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值