Главная страница
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.02 c
1-87928
Юлия
2003-03-17 13:56
2003.03.27
Макроподстановка


6-88122
Nicky
2003-02-06 20:11
2003.03.27
не могу пробиться через прокси


8-88080
rubaxa
2002-11-29 17:54
2003.03.27
Яркость, контрастность, четкость


1-87898
ghg
2003-03-13 08:41
2003.03.27
Нетипизированный файл и Tbitmap


6-88124
3d[Power]
2003-01-23 08:04
2003.03.27
Sockets, winsock.pas