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

Вниз

Удаление дочерних узлов   Найти похожие ветки 

 
RDA ©   (2002-07-16 17:47) [0]

Мастера подскажите как удалить дочерние узлы в дереве. Думаю что тригером BEFORE DELETE но как не пойму.


 
kaif ©   (2002-07-16 18:46) [1]

А чего тут думать?
Зависит от того, как дерево организовано.
В классическом случае (если поля ID,PARENT_ID, NAME) в триггер пишешь:
DELETE FROM <Table> WHERE PARENT_ID = OLD.ID;
Триггер рекурсивно сработает для всех вложенных узлов.



 
RDA ©   (2002-07-17 09:03) [2]

Благодарствую


 
Sergey13 ©   (2002-07-17 09:13) [3]

Не уверен, что сработает, но попробовать можно. Если поставить каскадное удаление по форинкею Parent_Id-Id то должно все удалиться и без тригера.


 
Leonid ©   (2002-07-17 10:19) [4]

Проверено на Oracle каскадное удаление по форинкею on self references table работает without any problem


 
Sergey13 ©   (2002-07-17 10:32) [5]

2Leonid © (17.07.02 10:19)
Ценное замечание по вопросу для IB6 8-)
Типа уж если на Оракле прокатило то уж ИБ точно проглотит?


 
kaif ©   (2002-07-17 12:37) [6]

Можно сделать и по FOREIGN KEY. Однако я боюсь, сначала надо будет добавить 1 корневую запись (с ID=0 и Parent_ID=0). Сделать ее на всякий неудаляемой (в триггере). Потом установить отношение FOREIGN KEY (ID) REFERENCES <та же таблица>(PARENT_ID) ON DELETE CASCADE.
IB поддерживает FOREIGN KEY таблицы на себя.
Хотя я предпочитаю в данном случае использовать триггер.



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

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

Наверх




Память: 0.48 MB
Время: 0.016 c
3-23856
ПИТОН
2002-07-17 08:54
2002.08.08
Остатки


1-23969
Arhangel
2002-07-25 15:47
2002.08.08
Иконки


3-23857
kserg@ukr.net
2002-07-19 13:46
2002.08.08
Хочу узнать мнение в подходах решения след.задачи


3-23930
Ag2002
2002-07-18 14:56
2002.08.08
Grid


1-24050
zetta
2002-07-24 19:03
2002.08.08
файлы по таймеру