Вы, вероятно, получаете эту ошибку:
ERROR 1093 (HY000): You can't specify target table 'table_1' for update in FROM clause.
Вы должны быть в состоянии сделать это, используя синтаксис MySQL для нескольких таблиц DELETE
:
DELETE table_1.*
FROM table_1,
table_2,
table_3
WHERE table_1.id = table_2.table_1_id
AND table_2.id = table_3.table_2_id
AND table_3.id = 5
Приведенный выше запрос должен работать, но, как правило, я бы рекомендовал вместо этого использовать синтаксис ANSI JOIN:
DELETE table_1.*
FROM table_1
INNER JOIN table_2 on table_2.table_1_id = table_1.id
INNER JOIN table_3 on table_3.table_2_id = table_2.id
WHERE table_3.id = 5