错误:You can't specify target table 'xxx' for update in FROM clause的解决

[ 2017-11-04 10:36:55 | 作者: admin ]
字号: | |
问题:  

  今天在MySQL数据库删除重复数据的时候遇到了一个问题。如下脚本:
DELETE FROM tempA WHERE tid IN (
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
)

  查询的时候增加一层中间表,就可以避免该错误。

http://www.cnblogs.com/pcheng/p/4950383.html
评论Feed 评论Feed: http://blog.xg98.com/feed.asp?q=comment&id=2459

这篇日志没有评论。

此日志不可发表评论。