从数据池中捞取的存储过程控件使用完以后必须unprepare

从数据池中捞取的存储过程控件使用完以后必须unprepare,否则会造成输入参数是仍是旧的BUG。

提示:动态创建的存储过程控件无此BUG。此BUG只限于从数据池中捞取的存储过程控件。

function TServerMethods1.spOpen(const accountNo, spName: WideString; inParams: OleVariant): OleVariant;
var
d: TfrmDB;
params: TParams;
i: Integer;
param: TFDParam;
begin
Result := null;
if (accountNo = '') or (spName = '') then
Exit;
d := GetDBPool(accountNo).Lock;
if not Assigned(d) then
Exit;
try
try
d.procOpen.Close;
d.procOpen.params.Clear;
d.procOpen.StoredProcName := spName;
d.procOpen.Prepare;
params := TParams.Create;
try
UnpackParams(inParams, params);
for i := 0 to params.Count - 1 do
begin
param := d.procOpen.FindParam(params[i].Name);
if not Assigned(param) then
Continue;
param.value := params[i].value;
end;
finally
params.Free;
end;
Result := d.dspProcOpen.Data;
except
on e: Exception do
begin
Result := null;
Log.WriteLog('TServerMethods1.spOpen ' + e.Message);
Exit;
end;
end;
finally
d.procOpen.Close;
d.procOpen.Unprepare;  // 从数据池中捞取的存储过程控件使用完以后必须unprepare
GetDBPool(accountNo).Unlock(d);
end;
end;

posted @   delphi中间件  阅读(597)  评论(0编辑  收藏  举报
编辑推荐:
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
阅读排行:
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?
点击右上角即可分享
微信分享提示