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;

怪哉。

相关推荐
2301_767902641 小时前
MySQL 入门
数据库·mysql
7ioik1 小时前
说一说MySQL数据库基本架构?
数据库·mysql·架构
东东的脑洞2 小时前
【面试突击】MySQL 查询优化核心面试知识点
mysql·面试·职场和发展
-dcr2 小时前
45.MySQL
mysql
大学生资源网3 小时前
基于Javaweb技术的宠物用品商城的设计与实现(源码+文档)
java·mysql·毕业设计·源码·springboot
小无名呀3 小时前
视图(View)
数据库·mysql
星光一影3 小时前
教育培训机构消课管理系统智慧校园艺术舞蹈美术艺术培训班扣课时教务管理系统
java·spring boot·mysql·vue·mybatis·uniapp
lkbhua莱克瓦243 小时前
MySQL介绍
java·开发语言·数据库·笔记·mysql
蜂蜜黄油呀土豆3 小时前
MySQL 锁机制全解析:从锁的分类到并发更新是否阻塞
mysql·innodb·并发控制·数据库锁·事务隔离级别
40kuai4 小时前
Mysql 主从同步
mysql