首页 > 解决方案 > 带有子查询的 mySQL UPDATE WHERE 给出错误

问题描述

我想用子查询更新表并且总是出错。现在我做了一个非常简化的版本(这没有多大意义,但显示了我的错误)

UPDATE a_test SET categoryID = '2956' WHERE id IN (
    (
        SELECT id from a_test
    )
)

这以此错误结束:

#1093 - Table 's_articles_categories' is specified twice, both as a target for 'UPDATE' and as a separate source for data

为什么我会收到此错误?当我为表 a_test 使用别名时,我得到了同样的错误。

这是我想使用的完整查询,但出现相同的错误:

UPDATE s_articles_categories SET categoryID = '2956' WHERE id IN
(
SELECT s_articles_categories.id FROM `s_articles`
LEFT JOIN s_articles_categories ON s_articles.id = s_articles_categories.articleID
WHERE s_articles_categories.categoryID NOT IN (
SELECT id FROM s_categories 
WHERE s_categories.id NOT IN (SELECT parent FROM s_categories WHERE parent IS NOT null GROUP BY parent)
)
)

标签: mysqlsubquery

解决方案


简化查询的一种解决方案是将子查询包装在另一个子查询中:

UPDATE a_test
SET categoryID = '2956'
WHERE id IN (SELECT id FROM (SELECT id FROM a_test) x );

这个技巧强制 MySQL 在 上实现子查询a_test,因此来自别名为 as 的子查询的值x不会随着更新的进行而受到影响。


推荐阅读