mysql - 带有子查询的 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)
)
)
解决方案
简化查询的一种解决方案是将子查询包装在另一个子查询中:
UPDATE a_test
SET categoryID = '2956'
WHERE id IN (SELECT id FROM (SELECT id FROM a_test) x );
这个技巧强制 MySQL 在 上实现子查询a_test
,因此来自别名为 as 的子查询的值x
不会随着更新的进行而受到影响。