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

Вниз

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

 
Тень отца Гамлета   (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;
Скачать: CL | DM;

Наверх




Память: 0.48 MB
Время: 0.046 c
14-1101493291
Fay
2004-11-26 21:21
2004.12.19
Нужен программер на пост. работу


1-1102143291
Лариса
2004-12-04 09:54
2004.12.19
Помоги спецы!!!


3-1100608109
Tor
2004-11-16 15:28
2004.12.19
из dbf в txt через TADODataSet


4-1099436174
Nix
2004-11-03 01:56
2004.12.19
Координаты мыши в "чужом" приложении.


4-1099758134
Владимир
2004-11-06 19:22
2004.12.19
Сообщение Windows