Delphi: Как получить значение выходного параметра хранимой процедуры? - PullRequest
7 голосов
/ 07 августа 2009

Я хочу программно создать SQLDataSet в Delphi и использовать его для выполнения хранимой процедуры и получения значения выходного параметра. Выглядит просто, но я не могу заставить его работать.

Вот глупая хранимая процедура в SQL Server:

CREATE PROCEDURE [dbo].getValue  @x INT OUTPUT
AS
BEGIN
  SET @x = 10;
END

Теперь вот один из вариантов, которые я пробовал и не работал:

proc := TSQLDataSet.Create(nil);
proc.SQLConnection := DefaultConnection;
proc.CommandText := 'getValue';
proc.Params.CreateParam(ftInteger, '@x', ptOutput);
proc.Params.ParamByName('@x').Value := 0;
proc.ExecSQL(False);
value := newIdProc.Params.ParamByName('@x').AsInteger;

Я думал, что это будет легко, но есть несколько зарегистрированных ошибок вокруг этой проблемы.

1 Ответ

7 голосов
/ 07 августа 2009

Похоже, это работает, если вы установите CommandType и SchemaName и не создаете Param:


proc := TSQLDataSet.Create(nil);
proc.SQLConnection := DefaultConnection;

proc.CommandType := ctStoredProc;
proc.SchemaName  := 'dbo';
proc.CommandText := 'getValue';

proc.ExecSQL(False);

value := proc.Params.ParamByName('@x').AsInteger;

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...