开发者社区> 问答> 正文

MySQL#1093-您无法在FROM子句中指定目标表'giveaways'进行更新?mysql

我试过了:

UPDATE giveaways SET winner = '1' WHERE ID = (SELECT MAX(ID) FROM giveaways) 但是它给出:

#1093-您不能为FROM子句中的更新指定目标表'giveaways'

展开
收起
保持可爱mmm 2020-05-17 22:33:27 30724 0
1 条回答
写回答
取消 提交回答
  • 这是因为您的更新可能是周期性的......如果更新该记录将导致事情发生这使得WHERE条件FALSE?您知道并非如此,但引擎并非如此。操作中桌子上也可能有相反的锁。

    我认为您可以这样做(未经测试):

    UPDATE giveaways SET winner = '1' ORDER BY id DESC LIMIT 1来源:stack overflow

    2020-05-17 22:33:38
    赞同 展开评论 打赏
问答排行榜
最热
最新

相关电子书

更多
搭建电商项目架构连接MySQL 立即下载
搭建4层电商项目架构,实战连接MySQL 立即下载
PolarDB MySQL引擎重磅功能及产品能力盛大发布 立即下载

相关镜像