MySQL 从 DENSE_RANK() 结果更新相同的表字段
Posted
技术标签:
【中文标题】MySQL 从 DENSE_RANK() 结果更新相同的表字段【英文标题】:MySQL update same table field from DENSE_RANK() results 【发布时间】:2020-04-28 18:12:40 【问题描述】:我正在尝试使用同一表中的 DENSE_RANK() 更新字段排名,同时尝试执行以下查询获取“操作数应包含 1 列”,请帮助解决此问题
UPDATE scoretable SET rank= (SELECT *,DENSE_RANK() OVER (PARTITION BY game_id ORDER BY points DESC , diff ASC) FROM scoretable WHERE STATUS ='Active')
表格详情
DENSE_RANK() 查询结果
SELECT *,DENSE_RANK() OVER (PARTITION BY game_id ORDER BY points DESC , diff ASC) FROM scoretable WHERE STATUS ='Active'
【问题讨论】:
直接错误原因是 SELECT * 但方法错误,考虑使用子查询作为游戏和用户得分表的连接。 你能帮我查询一下吗,我试过“更新 scoretable 作为 C 内连接 (SELECT DENSE_RANK() OVER (PARTITION BY game_id ORDER BY points DESC , diff ASC) as result FROM scoretable WHERE STATUS ='Active' )as A set C.Rank = A.result, "影响 0 行。 (查询耗时 0.0003 秒。) 【参考方案1】:正如 P.Salmon 所说:mysql 不允许更新的表出现在子查询中。相反,您可以在子查询中 dense_rank()
,然后在表中 join
它,如下所示:
update scoretable s
inner join (
select id, dense_rank() over(partition by game_id order by points desc, diff) rn
from scoretable
where status = 'Active'
) r on r.id = s.id
set s.rank = r.rn
注意:这里假定id
是表中的唯一键。
【讨论】:
以上是关于MySQL 从 DENSE_RANK() 结果更新相同的表字段的主要内容,如果未能解决你的问题,请参考以下文章
mysql窗口函数rank() over、dense_rank() over、row_number() over 使用心得
MySQL 5.6 - DENSE_RANK 类似没有 Order By 的功能
MySQL:与dense_rank()over()的group by和partition的差异输出?
MySQL中是不是有像Oracle这样的dense_rank()和row_number()这样的函数?
MySQL - 排序函数 Rank() Over()Dense_rank() Over()Row_number() Over()