【发布时间】: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