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

Вниз

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

 
AlexGof ©   (2003-03-07 11:01) [0]

Помогите чайнику ! Есть два набора данных ADODataSet связанных ключевым полем kod через добавление одного набора в другой методом связывания в свойстве MasterField, при втавке записи в мастер таблице методом append, код ключевого поля еще не сгенерирован в этой таблице, а нужно вставить еще запись и в подчиненную (с ней связанную), а потом вместе сохранить или выполнить откат. Ведь кода ключа нет и связки при такой вставке не происходит. Пробовал открывать транзакцию и выполнять Post после вставки записи, но кода ключа так и не появилось. А если запись вставлять с Update, то код ключа будет, но нет возможности выполнить одновременный откат на обе таблицы. Будет выполнен откат только на дочернюю естественно. Если кто сталкивался с такой проблемой, то просьба помочь. Заранее благодарен


 
Smashich ©   (2003-03-07 11:03) [1]

ИМХО такие вещи надо реализовывать через тригерры


 
sniknik ©   (2003-03-07 11:27) [2]

нашол тоже проблему

пишеш пакет команд и выполняеш (как оформить в виде тригера/процедуры/просто текста разници нет)
чтото подобное

ADOCommand.CommandText:=
"BEGIN TRANSACTION "+
"INSERT INTO Table1 (.....) VALUES (......) "+
"INSERT INTO Table2 (IDParent,....) VALUES (@@IDENTITY,......) "+
"COMMIT TRANSACTION";
ADOCommand.Execute;

это если ключ автоикремент, как я понял из вопроса так и есть, в 1 таблице он генерируется при вставке во вторую заносится его значение.


 
AlexGof ©   (2003-03-07 11:39) [3]

А если во вторую таблицу в дочернюю добавляется различное количество записей ?


 
sniknik ©   (2003-03-07 12:00) [4]

да пофиг сколько просто если во второй тоже есть инкремент и выывается не раз то значнение @@IDENTITY собьется, ну сделай переменную и сохрани
DECLARE @Iden Integer

BEGIN TRANSACTION
INSERT INTO Table1 (.....) VALUES (......)
SET @Iden @@IDENTITY
и после ей пользуйся (есть идентити с привязкой таблице можно и его использовать)


 
ermserg ©   (2003-03-07 12:20) [5]

>есть идентити с привязкой таблице можно и его использовать

IDENTITY_CARRENT(tablitsa)



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

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

Наверх




Память: 0.47 MB
Время: 0.016 c
1-88037
Shappo
2003-03-14 09:02
2003.03.27
Как сделать TPanel прозрачной ?


1-87971
boa
2003-03-17 13:38
2003.03.27
Как программно закрыть меню формы (TMainMenu)


3-87863
AlexGof
2003-03-07 11:01
2003.03.27
Работа с ADO под SQL Server


8-88077
sergn
2002-12-16 17:26
2003.03.27
Попадание курсором мыши на букву.


6-88128
andrey_pst
2003-02-05 08:51
2003.03.27
Почта с Indy.