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

Вниз

Какие параметры указать в транзакции, если нужно   Найти похожие ветки 

 
Тень отца Гамлета   (2004-11-19 14:18) [0]

Поле дочерней таблицы заполняется в зависимости от поля главной таблицы, которое генерируется триггером? После перезапроса главной таблицы все нормально, но если внести запись в главную таблицу, и попытаться добавить запись в дочернюю, то в некоторое поле попадет null - так как поле еще не сгенерировано триггером.
Компоненты FIBPlus 4.8


 
HSolo ©   (2004-11-19 14:26) [1]

Получайте значение поля на клиенте:

select gen_id(generator_name, 1) from rdb$database

а после этого вставляйте записи - и в главную таблицу, и в дочернюю.

А из триггера или уберите gen_id совсем, или напишите так:

if (new.id is null) then
 new.id = gen_id(generator_name, 1);


 
Тень отца Гамлета   (2004-11-19 14:30) [2]

Да не про генераторы вопрос...


 
Sergey13 ©   (2004-11-19 14:31) [3]

[2] Тень отца Гамлета   (19.11.04 14:30)
>Да не про генераторы вопрос...

Так и ответ то был не про них. 8-)


 
Тень отца Гамлета   (2004-11-19 16:22) [4]

Тут проблема вот в чем. Если сделать запись в главной таблице, а потом ее обновит (завершить транзакцию), то добавление в подчиненной таблице работает правильно.
Если же добавить запись в главную и сразу же попытаться записать в дочернюю, то получаю исключение

violation of FOREIGN KEY constraint "FK_CHILDTABLE_MASTER_ID" on table "CHILDTABLE".

Т.е. не находится внешний ключ в главной таблице.
Однако в InsertSQL в дочерней  используется :MAS_MASTER_ID, что автоматом подставляет ID из главной таблице, и при просмотре лога sql видим, что таки правда, такой код и подставляется. Но ошибка генерируется


 
Term   (2004-11-19 18:37) [5]


> if (new.id is null) then
>  new.id = gen_id(generator_name, 1);

слушай советы не зря говорят, и подумай что происходит условие в тригере не просто так,
и вставляй в зависимую таблицу запись после того как произойдёт вставка в главную



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

Форум: "Базы";
Текущий архив: 2004.12.19;
Скачать: [xml.tar.bz2];

Наверх





Память: 0.45 MB
Время: 0.043 c
3-1101202428
S@lik
2004-11-23 12:33
2004.12.19
Проблема с ковычками


1-1101865961
PEKAHT
2004-12-01 04:52
2004.12.19
Image мигает


14-1101713605
OneFragLeft
2004-11-29 10:33
2004.12.19
Меня обманули?


1-1102411493
Maxuz
2004-12-07 12:24
2004.12.19
Обращение к контролам на форме при динамическом её создании...


14-1101397539
Kerk
2004-11-25 18:45
2004.12.19
Windows Media Player готовился с помощью вареза





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
Английский Французский Немецкий Итальянский Португальский Русский Испанский