在MySQL中,写SQL语句的时候 ,可能会遇到You can't specify target table '表名' for update in FROM clause这样的错误,它的意思是说,不能先select出同一表中的某些值,再update这个表(在同一语句中),即不能依据某字段值做判断再来更新某字段的值。
1、数据准备
product表数据如下:
laptop表数据如下:
2、要求:#删除所有不生产打印机厂商生产的笔记本电脑
第一步:对aptop表进行操作
操作没有问题,按照本思路对product表进行操作
产生You can't specify target table '表名' for update in FROM clause错误
3、问题解决
将SELECT出的结果再通过中间表SELECT一遍,这样就规避了错误。
需要注意的是,这个问题只出现于MySQL,MSSQL和Oracle不会出现此问题。
本文探讨了在MySQL中执行包含SELECT与UPDATE操作的复合语句时遇到的“You can't specify target table '表名' for update in FROM clause”错误,并通过实例展示了如何使用中间表来避免这一问题。
9862

被折叠的 条评论
为什么被折叠?



