Có thể bạn đang gặp lỗi này:
ERROR 1093 (HY000): You can't specify target table 'table_1' for update in FROM clause.
Bạn có thể thực hiện việc này bằng cách sử dụng multi-table DELETE
cú pháp thay thế:
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
Truy vấn trên sẽ hoạt động, nhưng theo quy tắc chung, tôi khuyên bạn nên sử dụng cú pháp ANSI JOIN thay thế:
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