MySQL—嵌套select使用该表时如何从表中删除?

时间:2022-10-15 17:08:17

I'm trying to do something like this:

我试着做这样的事情:

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) 

Seems like MySQL won't let me have table_1 in the nested SELECT. Suggestions?

看起来MySQL不会让我在嵌套选择中有table_1。建议吗?

1 个解决方案

#1


4  

You're probably getting this error:

你可能会犯这样的错误:

ERROR 1093 (HY000): You can't specify target table 'table_1' for update in FROM clause.

You should be able to do this using MySQL's multiple-table DELETE syntax instead:

您应该能够使用MySQL的多表删除语法来实现这一点:

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

The above query should work, but as a general rule I would recommend using ANSI JOIN syntax instead:

上述查询应该是有效的,但作为一般规则,我建议使用ANSI连接语法:

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

#1


4  

You're probably getting this error:

你可能会犯这样的错误:

ERROR 1093 (HY000): You can't specify target table 'table_1' for update in FROM clause.

You should be able to do this using MySQL's multiple-table DELETE syntax instead:

您应该能够使用MySQL的多表删除语法来实现这一点:

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

The above query should work, but as a general rule I would recommend using ANSI JOIN syntax instead:

上述查询应该是有效的,但作为一般规则,我建议使用ANSI连接语法:

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