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

Вниз

Есть ли в Paradox каскадное удаление?   Найти похожие ветки 

 
__alex ©   (2006-05-08 19:24) [0]

Берем 2 таблицы (Paradox 7), связываем их по некому полю отношением один-ко-многим. Update rule выбираем Cascade. И потом пытаемся удалить запись из главной (master) таблицы.
Если при этом в подчиненной таблице существует одна или несколько записей, соответствующих выбранной в главной таблице записи, то получаем такую ошибку:
Master has detail records. Cannot delete or modify.
Я что то делаю не так или в paradox и правда нет возможности каскадного удаления?


 
mike-d ©   (2006-05-08 19:34) [1]


> Есть ли в Paradox каскадное удаление?

Нет. Есть только каскадный UPDATE.


 
__alex ©   (2006-05-08 20:19) [2]

Тогда такой вопрос. В описаном выше случае где одна мастер-таблица и одна подчиненная, каскадное удаление можно организовать простеньким sql-запросом вроде
DELETE FROM detailTable WHERE Id=...
ну и потом удаление записи в мастер-таблице.
Но че делать если у нас например 3 или более таблиц:
table1 (master-detail) table 2 (master-detail) table3
и надо удалить запись из "самой главной" таблицы table1? Че то на ум ничего хорошего не приходит кроме перелопачивания всех записей в рекурсии. А никак это попроще нельзя сделать? Ну не обязательно sql-запросом, может другое какое решение есть?


 
mike-d ©   (2006-05-08 22:53) [3]


> на ум ничего хорошего не приходит кроме перелопачивания
> всех записей


Ничего и не придет наверное больше :)

Повесь удаление detail"ов на BeforeDelete master-таблицы - примерно так:

procedure Data.Table1BeforeDelete(...);
begin
 Table2.First;
 while not Table2.Eof do Table2.Delete;
end;

procedure Data.Table2BeforeDelete(...);
begin
 Table3.First;
 while not Table3.Eof do Table3.Delete;
end;


 
__alex ©   (2006-05-08 23:17) [4]

Угу, ты прав, mike-d... Блин, неудобно все это...



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

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

Наверх




Память: 0.47 MB
Время: 0.03 c
2-1150039565
learner
2006-06-11 19:26
2006.07.02
Правильное ведение лога с использованием нитей


3-1146917274
Ярослав
2006-05-06 16:07
2006.07.02
как убраить masterkey


15-1149709555
Prohodil Mimo
2006-06-07 23:45
2006.07.02
Вот как у нас город украсили :о)


15-1149649877
YurikGL
2006-06-07 07:11
2006.07.02
Теперь известен уровень взяток министрам - 1 млн $


1-1148540258
.ruslan
2006-05-25 10:57
2006.07.02
...узнать сколько времени прошло (осталось) между датами