Главная страница
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.013 c
1-32820
serg
2002-04-01 13:17
2002.04.11
update 2 for Delphi 6


6-32919
Malyatkoya
2002-01-16 17:50
2002.04.11
Нужен совет.


1-32882
PlaZZma
2002-03-29 16:11
2002.04.11
Как работать с TPicture?


1-32877
XAU
2002-03-28 18:01
2002.04.11
тип Variant


3-32621
tovSuhov
2002-03-22 14:28
2002.04.11
Ограничение на кол-во записей...