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

Вниз

Косяки в Master-Detail   Найти похожие ветки 

 
nick-from ©   (2002-10-19 11:19) [0]

Есть Master-Detail связь. В Master таблице при вставке новой записи ее ID создантся с помощью генератора и триггера:

CREATE GENERATOR NEW_CATEGORY;

CREATE TRIGGER NEW_CATEGORY_ID FOR CATEGORIES
ACTIVE BEFORE INSERT POSITION 0
AS
BEGIN
NEW.ID = GEN_ID(NEW_CATEGORY, 1);
END

Проблема в том, что возникает ошибка при перечитывании только что вставленной записи клиентским приложением (Создаем запись в Master"е и сразу же для этой новой записи пытаемся создать записи в Detail, где требуется ID вставленной Master-записи для связки)
Как такой проблемы можно избежать.
Можно вызвать сразу после вставки новой записи Master.CloseOpen, но по-моему это косяк
P.S. при удалении только что вставленной Master-записи та же беда


 
lejik ©   (2002-10-19 19:04) [1]

ApplyUpdates
CommitRetaining для Master


 
kaif ©   (2002-10-19 20:16) [2]

Странно. Подобные вопросы возникают чуть ли не каждый день. Откуда берется эта повальная манера получать значение ID в триггере BEFORE INSERT? Видно, это рекомендует какая-то очень умная книжка...
Разумеется, если неизвестно ID на клиентской стороне сразу после вставки, то будут проблемы. Следовательно нет иного способа этот ID узнать как один из 2:
1. Делать INSERT при помощи хранимой процедуры, возвращающей значение ID в RESULTS.
2. Сначала запрашивать новое значение генератора клиентом и вставлять запись с уже явно присвоенным ID. Компоненты IBX содержат реализацию этого подхода. Достаточно прописать атрибуты свойства Generator. Перед вставкой (INSERT) клмпонент TIBDataSet или его потомок сам запросит новое значение генератора с помощью SQL-запроса:
SELECT GEN_ID(NEW_CATEGORY, 1) FROM RDB$DATABASE;
Затем, он присвоит это значение полю ID, указанному в свойстве Generator и только потом выполнит INSERT. Тогда проблем не будет.



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

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

Наверх




Память: 0.47 MB
Время: 0.019 c
14-21737
Igorek
2002-10-16 19:50
2002.11.07
Как перекинуть текст из разных HTML файлов в один?


1-21602
KIR
2002-10-25 13:27
2002.11.07
Как пихнуть иконку в exe шник


1-21590
MegaVolt
2002-10-30 11:24
2002.11.07
Как можно сделать редактирование наследника от TForm визуально?


1-21604
Beginner-Designer
2002-10-25 19:47
2002.11.07
проблема с использованием горячих клавиш


7-21827
Frog_killer
2002-09-06 00:01
2002.11.07
Как получить информацию о процессоре?