错误:You can't specify target table 'xxx' for update in FROM clause的解决
[ 2017-11-04 10:36:55 | 作者: admin ]
问题:
今天在MySQL数据库删除重复数据的时候遇到了一个问题。如下脚本:
会出现报错信息:
You can't specify target table 'tempA' for update in FROM clause
大致意思是,在同一语句中,不能先select出同一表中的某些值,再update这个表。
解决方法:
需要对上述脚本进行改造,如下:
查询的时候增加一层中间表,就可以避免该错误。
http://www.cnblogs.com/pcheng/p/4950383.html
评论Feed: http://blog.xg98.com/feed.asp?q=comment&id=2459
今天在MySQL数据库删除重复数据的时候遇到了一个问题。如下脚本:
DELETE FROM tempA WHERE tid IN (
SELECT MAX(tid) AS tid FROM tempA GROUP BY name,age
)
SELECT MAX(tid) AS tid FROM tempA GROUP BY name,age
)
会出现报错信息:
You can't specify target table 'tempA' for update in FROM clause
大致意思是,在同一语句中,不能先select出同一表中的某些值,再update这个表。
解决方法:
需要对上述脚本进行改造,如下:
DELETE FROM tempA WHERE tid NOT IN (
SELECT t.tid FROM (
SELECT MAX(tid) AS tid FROM tempA GROUP BY name,age
) t
)
SELECT t.tid FROM (
SELECT MAX(tid) AS tid FROM tempA GROUP BY name,age
) t
)
查询的时候增加一层中间表,就可以避免该错误。
http://www.cnblogs.com/pcheng/p/4950383.html

这篇日志没有评论。
此日志不可发表评论。