【问题标题】:MySQL update same table field from DENSE_RANK() resultsMySQL 从 DENSE_RANK() 结果更新相同的表字段
【发布时间】:2023-03-03 01:37:01
【问题描述】:

我正在尝试使用同一表中的 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 秒。)

标签: mysql sql sql-update window-functions dense-rank


【解决方案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 是表中的唯一键。

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2013-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 2013-03-31
    • 2014-02-14
    • 2012-11-03
    • 1970-01-01
    相关资源
    最近更新 更多