Главная страница
    Top.Mail.Ru    Яндекс.Метрика
Форум: "Базы";
Текущий архив: 2003.03.27;
Скачать: [xml.tar.bz2];

Вниз

Работа с 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;
Скачать: [xml.tar.bz2];

Наверх




Память: 0.45 MB
Время: 0.009 c
9-87768
JB
2002-10-28 12:05
2003.03.27
Всё те же спрайты................................................


1-88027
Z_man7777
2003-03-14 07:18
2003.03.27
Нажав на кнопку, как оставить фокус на предыдущем контроле


7-88267
Ifrit
2003-02-03 19:45
2003.03.27
RTF--->Word и обратно


14-88194
Alexsys
2003-03-11 08:55
2003.03.27
Литература по TCP, портам и т.д.


3-87797
Шумахер
2003-03-07 03:38
2003.03.27
Помогите с IBDataset





Afrikaans Albanian Arabic Armenian Azerbaijani Basque Belarusian Bulgarian Catalan Chinese (Simplified) Chinese (Traditional) Croatian Czech Danish Dutch English Estonian Filipino Finnish French
Galician Georgian German Greek Haitian Creole Hebrew Hindi Hungarian Icelandic Indonesian Irish Italian Japanese Korean Latvian Lithuanian Macedonian Malay Maltese Norwegian
Persian Polish Portuguese Romanian Russian Serbian Slovak Slovenian Spanish Swahili Swedish Thai Turkish Ukrainian Urdu Vietnamese Welsh Yiddish Bengali Bosnian
Cebuano Esperanto Gujarati Hausa Hmong Igbo Javanese Kannada Khmer Lao Latin Maori Marathi Mongolian Nepali Punjabi Somali Tamil Telugu Yoruba
Zulu
Английский Французский Немецкий Итальянский Португальский Русский Испанский