用Delphi 7,BDE和OracleORA-01000:最大打开的游标超出
我执行SQL SELECT语句,然后通过各自的返回set的记录步骤,并执行以下更新SQL
var
AQuery: TQuery;
begin
AQuery:= TQuery.Create(nil);
AQuery.DatabaseName:= ADatabase.DatabaseName;
with AQuery do
begin
SQL.Text:= 'UPDATE AP_Master SET CMCL_FORECAST_CLEARED=:AClearedDate WHERE ID=:AMasterId';
ParamByName('AMasterId').AsString:= IntToStr(AId);
ParamByName('AClearedDate').AsDateTime:= StrToDateTime(FormatDateTime('mm/dd/yyyy', AForeCastClearedDate));
try
ExecSql;
except on E: Exception do
begin
raise Exception.create('Error Updating AP_Master Tables Forecast Cleared Date!' + E.Message);
end;//except
end; //try
end; //with
AQuery.Close;
AQuery.Free;
end;
它的工作原理为福斯特500分+的记录,但后来我得到一个:ORA-01000:最大打开的游标超出消息
有什么我需要在BDE侧做,Oracle方面,或在我的代码(使用标准TQuery和TDatabase组件的Im)
你看过http://mail.dir.bg/~radoslav.rusinov/Blog/How.to.Cope.with.an.ORA-01000.Error-v.2.1。 pdf? – SimaWB 2011-04-28 12:26:29
你至少应该把Close()和Free()放在try/finally块中。但我不认为这会解决问题。 – 2011-04-28 12:28:15
ParamByName('AMasterId')。AsString:= IntToStr(AId);可以简单地写成ParamByName('AMasterId')。AsInteger:= AId;也许你可以在日期上做同样的事情。为什么获取日期,将其转换为字符串,然后获取该字符串并将其转换为日期?如果您只需要获得日/月/年的部分,则有更好的方法(即Trunc())。 – 2011-04-28 15:00:51