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

Вниз

Тригер в sql server   Найти похожие ветки 

 
aaaaa   (2008-09-01 16:09) [0]

в базе на таблицу по after insert есть триггер, который тож инсертит что-то там в другую табл.

код моего добавления
ADoConnection.BeginTrans;
q.Insert;
q.FieldByName("A").AsString := ";sdfg";
q.Post;
ADOConnection.commit;

проблемма в том, что теперь первичный ключ таблицы запроса после вставки равен тому ключу, который вставляет триггер:(. Я так понимаю @@IDENTITY
Как правильно сделать?


 
Ega23 ©   (2008-09-01 16:13) [1]


> Как правильно сделать?


Я так понимаю, что у тебя MSSQL.
Читать в BOL разницу между @@IDENTITY, SCOPE_IDENTITY() и IDENT_CURRENT.

Как раз твой случай там подробно описан.


 
aaaaa   (2008-09-01 16:18) [2]


> Ega23 ©   (01.09.08 16:13) [1]

разницу я знаю(пробежал мельком), но ведь это занчение - @@IDENTITY - берет запрос(ADO), запросу-то как мне указать, откуда брать последний инсерт? Он правильно и поступает, что берет именно @@IDENTITY... Не знаю, что и делать, ведь эта переменная тока для чтения, вроде?


 
Ega23 ©   (2008-09-01 16:39) [3]

Блин.


with ADODataSet do
begin
 CommandText := "Set noCount ON; " +
                         "Insert into Table1(.....) Values (.....); " +
                         "Select Result = Scope_Identity()";
 try
   try
      Open;
      ID := FieldByName("Result").AsInteger;
   except on E : Exception do
     .......
   end;
 finally
    Close;
 end;
end;


 
aaaaa   (2008-09-01 17:04) [4]


> Ega23 ©   (01.09.08 16:39) [3]

спасибо.

....

блин, мне менять TADOQuery на TADODataSet из-за этого?


 
Ega23 ©   (2008-09-01 17:12) [5]


> блин, мне менять TADOQuery на TADODataSet из-за этого?


Можешь не менять. Но я бы посоветовал использовать TADODataSet там, где возвращается набор данных и TADOCommand там, где не возвращается.


 
Ega23 ©   (2008-09-01 17:13) [6]

Да, для TADOQuery тогда вместо CommandText подставь SQL.Text



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

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

Наверх




Память: 0.47 MB
Время: 0.016 c
2-1220355260
vvrz
2008-09-02 15:34
2008.10.12
из Memo в Excel


2-1220596870
_Alex
2008-09-05 10:41
2008.10.12
CreateFileMapping не возвращает ошибку, когда отключен swap-файл


2-1220611069
Mundrik
2008-09-05 14:37
2008.10.12
Защита от перезаписи кодав памяти


2-1220207979
fog
2008-08-31 22:39
2008.10.12
MD5 и CryptoAPI


15-1219351890
TUser
2008-08-22 00:51
2008.10.12
Ширли-мырли