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

Вниз

Ссылочная целостность   Найти похожие ветки 

 
Pat ©   (2003-03-05 21:38) [0]

Работаю с Paradox через BDE. Есть две таблицы Master-Detail. Настраиваю ссылочную целостность. Update rule=cascade. При удалении записи из Master"а, при условии, что в Detail есть связанные с Master записи, вылетает ошибка "Master has detail records. Cannot delete or modify". Как с этим бороться?


 
MsGuns ©   (2003-03-05 22:23) [1]

Для парадокса какскад не работает. Правда, можно через DataModule->Diagram, но не советую - при любых изменениях, напрмер, в десктопе, модуль "летит" бесповоротно (и не только он)

Выход один: "спускаться" в детал и там в цикле удалять. Хуже с апдейтом - при изменении связующего ключа в детале весьма высока вероятность общего "полета" индексов и ключей физ.таблицы.

Проще использовать вместо таблиц запросы и события BeforeDelete


 
mike-d ©   (2003-03-06 01:36) [2]

> Pat © (05.03.03 21:38)
"Master has detail records. Cannot delete or modify"
Нормальная реакция BDE. Где-то в HELP (забыл ссылку, к сожалению) так и написано, что при попытке удаления записи имеющей дочерние - это дело блокируется. Сначала надо ручками удалить все дочерние. Зато каскадное изменение ключа - как из пулемета. (См. BDE-Help-Integrity constraints)
> MsGuns © (05.03.03 22:23)
> Для парадокса какскад не работает.

Не согласен. При создании таблиц в Database Desktop назначаешь это самое "referential integrity" - и все работает тип-топ (в однопользовательском, локальном варианте, в сети не пробовал...) - правда это не освобождает от назначения Master-Detail в программе...


 
Grom   (2003-03-06 08:56) [3]

Таже проблема. ставишь Update rule=cascade. потом смотришь через Sql explorer, в таблицах на соботытие update стоит cascade, а на delеte стоит restrict. хотя в хелпе Database Desktop написано что должно на delete удалять записи в дочерней таблице.
Выход нашел тока через события BeforeDelete в Delphi.


 
VAleksey ©   (2003-03-06 10:17) [4]

А другого пути нет.
Я не сказал бы что это обман, просто мастера из борланда
чуть-чуть не договаривают.



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

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

Наверх




Память: 0.47 MB
Время: 0.021 c
14-76639
Denton
2003-03-06 17:57
2003.03.24
XP gluk


3-76333
Merlot
2003-03-05 10:26
2003.03.24
Вопрос по Query


8-76527
ДокКир
2002-12-14 15:18
2003.03.24
Графика


14-76658
blackman
2003-03-08 16:42
2003.03.24
С праздничком ! Что-то грустно.


1-76480
Jel
2003-03-11 12:20
2003.03.24
Крвая работа D6 с COM или все-таки руки?