繁体   English   中英

MySQL使用max函数使用子查询更新查询

[英]MySQL update query with subquery using max function

任何人都可以看到以下查询有什么问题吗?

update sub set name='dd' where salary=(select max(salary) from sub);

执行发现错误后,MariaDB 说,

SQL 查询:文档

更新子集名称='dd' wheresalary=(select max(salary) from sub)

MySQL 说: 文档

\\ #1093 - 表 'sub' 被指定两次,既作为 'UPDATE' 的目标,也作为单独的数据源

MySQL 中不允许使用此语法。 您可以使用一个join ,而不是:

update sub s
inner join (select max(salary) salary from sub) m on m.salary = s.salary
set s.name = 'dd'

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM