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

Вниз

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

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

Наверх




Память: 0.45 MB
Время: 0.009 c
3-76345
Mic_2000
2003-03-05 16:12
2003.03.24
Как сделать чтобы IBDatabase не конектился сам при запуске?


1-76465
Dracula2000
2003-03-12 11:41
2003.03.24
Dll


4-76723
VinRaider
2003-01-25 17:54
2003.03.24
Размещение папки Windows


3-76327
Злодей
2003-03-05 18:38
2003.03.24
Данные из поля в таблице


3-76266
SZap
2003-03-06 11:40
2003.03.24
Програмное создание Таблици





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