Главная страница
Top.Mail.Ru    Яндекс.Метрика
Текущий архив: 2002.04.11;
Скачать: CL | DM;

Вниз

Работа с ADO   Найти похожие ветки 

 
AndrewK ©   (2002-03-19 12:54) [0]

Как выполнить запрос на вставку записи с возвращением числа.
Есть хранимая процедура на MSSQL Server 7, которая вставляет записи в таблицу и возвращает идентификационный номер записи, получаемый внутри процедуры переменной @@Identity. С помощью TQuery раньше делал так:

with TQuery.Create(nil) do
try
SQL.Text := "MyStoredProc ....";
Active := True;
NewID = FieldByName("NewID").AsInteger;
finally
Active := False;
Free;
end;

Все работало

Комбинация
with TADOQuery.Create(nil) do
try
SQL.Text := "MyStoredProc ....";
Active := True;
NewID = FieldByName("NewID").AsInteger;
finally
Active := False;
Free;
end;
не работает. Выдается сообщение "CommandText does not return a result set."

Процедура значение возвращает в любом случае. Как можно выполнить процедуру и получить значение с помощью ADO?


 
alehan ©   (2002-03-19 14:33) [1]

Для вызова хранимой процедуры логичнее бы было использовать TADOStoredProc.


with TADOStoredProc.Create(self) do
try
Connection:=...;
ProcedureName:="MyStoredProc;1";
ExecProc;
NewID := Parameters.ParamByName("@NewID").Value;
finally
Free;
end;


 
Дмитрий ©   (2002-03-19 15:54) [2]

rs.close; //rs - TAdoQuery
rs.sql.text:="insert into tbl values("1", "2", 3"); select @@identity as C1 from tbl";
rs.Open;
{int} identity = rs.fieldbyname("C1").asinteger;


 
Дмитрий ©   (2002-03-19 15:56) [3]

Пардон, грамотней так: (""1"", ""2"", ""3"")
:))



Страницы: 1 вся ветка

Текущий архив: 2002.04.11;
Скачать: CL | DM;

Наверх




Память: 0.47 MB
Время: 0.011 c
4-33022
Nuhim
2002-02-07 11:36
2002.04.11
Перехват запуска программ.


1-32826
Maxman
2002-03-27 13:58
2002.04.11
Нужно описание алгоритма


14-32944
IronHawk
2002-02-27 16:22
2002.04.11
Как программно определить, создана ли дочерняя форма ?


3-32685
Seri
2002-03-21 09:06
2002.04.11
SQL Insert и Boolean


1-32828
LiNkS
2002-03-28 18:39
2002.04.11
GIF в Delphi