mysql 从同一个表获取数据update自身报错一例

我在mysql中,想将一些记录的某个字段,改成跟某条记录的该字段的值一样,语句如下:

sql 复制代码
update org_user set password=(select password from org_user where loginname='admin' limit 1) where userid>1000;

结果就报错了,提示:

Error Code: 1093. You can't specify target table 'org_user' for update in FROM clause。看这意思,不能从表中获取数据来更新自己?

果然,如果从别的表拿数据就可以:

sql 复制代码
--克隆一个表
create table org_user_tmp as select * from org_user;

--从正式表拿数据更新克隆表,OK
update org_user_tmp set password=(select password from org_user where loginname='admin' limit 1) where userid>1000;

这种语句在别的数据库,比如oracle,是没有问题的。来到mysql就不行了。后来改成这样就可以了:

sql 复制代码
update org_user as u1 
join(select password from org_user where loginname='admin' limit 1) as u2
set u1.PASSWORD=u2.password
where u1.userid>1000;

怪哉。

相关推荐
White_Mountain6 小时前
在Ubuntu中配置mysql,并允许外部访问数据库
数据库·mysql·ubuntu
老王笔记6 小时前
GTID下复制问题和解决
mysql
Lojarro8 小时前
【Spring】Spring框架之-AOP
java·mysql·spring
TianyaOAO8 小时前
mysql的事务控制和数据库的备份和恢复
数据库·mysql
Ewen Seong8 小时前
mysql系列5—Innodb的缓存
数据库·mysql·缓存
W215510 小时前
Liunx下MySQL:表的约束
数据库·mysql
nbsaas-boot11 小时前
探索 JSON 数据在关系型数据库中的应用:MySQL 与 SQL Server 的对比
数据库·mysql·json
奥顺11 小时前
PHPUnit使用指南:编写高效的单元测试
大数据·mysql·开源·php
苹果醋313 小时前
SpringBoot快速入门
java·运维·spring boot·mysql·nginx
ROCKY_81713 小时前
Mysql复习(一)
数据库·mysql