Текущий архив: 2003.05.15;
Скачать: CL | DM;
Вниз
Ступенчатое удаление Найти похожие ветки
← →
MsGuns (2003-04-24 18:33) [0]Или "закат солнца вручную". В принципе надо сделать каскадное удаление в таблицах, где оно не определено в метаданных.
Итак, есть 4 таблицы, организующие иерархию наподобие дерева.
0-й (высший) ур. NOUT - накладные отгрузки (Key: NID)
1-й ур. - фактура отгружаемых изделий (Key: NPID, Link:NID)
2-й ур. - списание видов матер-в в изд. (Key: NPNID, Link:NPID)
3-й ур. - списание мат-лов с приходов (Key: NPNMID, Link:NPNID)
Везде определены ForegnKey для "родительских" ключей.
Удалять надо, ессно, сначала из 3-й, затем из 2-й и т.д.
Сделать надо запросами (не ХП и не триггерами), т.е. не правя метаданные.
Обломался на первом же (самом многоэтажном):
DELETE FROM nout_pm PM
WHERE PM.npnid=
(SELECT PN.npnid FROM nout_pn PN
WHERE PN.npid=
(SELECT P.npid FROM nout_p P
WHERE P.nid=:pNID)
)
Кричит, что множественность в единственной выборке. Вставка после вложенных Select`ов "DISTINCT" ничего не меняет.
Используется FB 1.0 (V6.2)
Понимаю, что дурак, но не знаю почему ;)))
Благодарю всех откликнувшихся !
← →
KoluChi (2003-04-24 18:37) [1]может попробовать вместо WHERE PM.npnid=
WHERE PM.npnid IN (
← →
MsGuns (2003-04-24 18:38) [2]SELECT * FROM nout_pm PM
WHERE PM.npnid=
(SELECT PN.npnid FROM nout_pn PN, nout_p P
WHERE (PN.npid=P.npid) And (P.nid=4))
Тоже не пашет.
>KoluChi © (24.04.03 18:37)
Сейчас попробую.
← →
Arm79 (2003-04-24 18:55) [3]попробуй так
DELETE FROM table3 t3
WHERE t3.npnid in
(SELECT t2.npnid FROM table2 t2
WHERE t2.npid in
(SELECT t1.npid FROM table1 t1
WHERE t1.nid in
(select t0.nid from
table0 t0
where t0.nid = :param)
)
)
← →
MsGuns (2003-04-24 19:05) [4]Прошло и так:
SELECT * FROM nout_pm PM
WHERE PM.npnid in
(SELECT PN.NPNID FROM nout_pn PN
WHERE PN.npid in
(SELECT P.npid FROM nout_p P
WHERE P.nid=4)
)
и так:
SELECT * FROM nout_pm PM
WHERE PM.npnid in
(SELECT PN.npnid FROM nout_pn PN, nout_p P
WHERE (PN.npid=P.npid) And (P.nid=4))
Замена SELECT * на DELETE и все O`k !!!
ВСЕМ ОГРОМНОЕ СПАСИБО !!!
ЗЫ. А ведь мог же и сам догадаться. ;((
Страницы: 1 вся ветка
Текущий архив: 2003.05.15;
Скачать: CL | DM;
Память: 0.45 MB
Время: 0.006 c