MySQL - Как удалить из таблицы, когда вложенная выборка использует эту таблицу? - PullRequest
3 голосов
/ 18 мая 2011

Я пытаюсь сделать что-то вроде этого:

DELETE FROM table_1
WHERE  table_1.id IN (SELECT table_1.id
                      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) 

Похоже, что MySQL не позволит мне иметь table_1 во вложенном SELECT. Предложения?

1 Ответ

4 голосов
/ 18 мая 2011

Вы, вероятно, получаете эту ошибку:

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
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...