码迷,mamicode.com
首页 > 其他好文 > 详细

DATASNAP中间件调用带OUTPUT参数的存储过程

时间:2015-11-01 17:53:21      阅读:569      评论:0      收藏:0      [点我收藏+]

标签:

服务端:

 

function TServerMethods1.spExecOut(funcId, sqlId,

inParams: OleVariant): OleVariant;
var
d: TfrmDB;
procName: string;
params: TFDParams;
i, h: Integer;
begin
Result := null;
d := DBPool.Lock;
if not Assigned(d) then
Exit;
try
try
procName := frmBuffer.GetSqlSelect(funcId, sqlId);
if procName = ‘‘ then
Exit;
d.proc.Close;
d.proc.StoredProcName := procName;
d.proc.Prepare;
params := TFDParams.Create;
try
UnpackFDParams(inParams, params);
for i:=0 to params.Count -1 do
for h:=0 to d.proc.ParamCount-1 do
if d.proc.Params[h].Name = params[i].Name then
begin
if d.proc.Params[h].ParamType=ptInput then
begin
d.proc.Params[h].Value := params[i].Value;
Break;
end;
end;
finally
params.Free;
end;
d.proc.ExecProc;
Result := PackageFDParams(d.proc.Params);
except
on e: Exception do
begin
Result := null;
Log.WriteLog(‘TServerMethods1.spExecOut ‘ + e.Message);
Exit;
end;
end;
finally
DBPool.Unlock(d);
end;
end;

 

客户端调用:

 

procedure TfrmMain.Button2Click(Sender: TObject);
var
r:OleVariant;
p:TParams;
begin
p:=TParams.Create(nil);
p.Clear;
p.CreateParam(ftInteger,‘@a‘,ptInput).Value :=1;
p.CreateParam(ftInteger,‘@b‘,ptInput).Value :=2;
p.CreateParam(ftInteger,‘@c‘,ptOutput);
r := spExecOut(‘9999‘,‘3‘,PackageParams(p));
UnpackParams(r,p);
p.ParamByName(‘@c‘).Value;
p.Free;
end;

end.

DATASNAP中间件调用带OUTPUT参数的存储过程

标签:

原文地址:http://www.cnblogs.com/hnxxcxg/p/4928187.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!