lllrc 2021-08-29 15:35 采纳率: 0%
浏览 21

sql中如何对省中的市进行排序 二次分区?

题目如下,如何对对每个省中的市进行uv排序?
想要的结果市:

uv
广东深圳4000
广东广州3000
广东x2000
类似这个样子的表结构

img

  • 写回答

1条回答 默认 最新

  • daleHaven 2021-08-29 16:47
    关注

    我使用的是HQL语言:解决这个问题非常简单

    1. 将uv_tbl join money_tbl on pron
    2. 使用开窗函数将相同省份的表放到一个窗口中,然后根据uv进行排名,再来个RANK()函数直接附带上排名,完美解决,基本伪HQL编写(我意思一下,可别照抄,只是表达思想)如下所示
      SELECT *,RANK() OVER(PARTITION BY t1.prov ORDER BY t1.uv DESC) FROM (uv_tbl join money_tbl)t1
      即可完成

    其他SQL个人的解决方案也有partition这种函数吧...

    评论

报告相同问题?

问题事件

  • 创建了问题 8月29日

悬赏问题

  • ¥15 使用dify通过OpenAI 的API keys添加OpenAI模型时报了“Connection Error”错误
  • ¥15 请帮我看一下问题出在哪里
  • ¥15 如何解决图中的问题,localhost现实无法访问此页面
  • ¥40 想找个软件,但我不知道怎么找到它,我甚至不知道有没有
  • ¥15 怎么把60秒的视频时长改成显示0秒?且视频内容没有任何变化的正常播放?目的是为了解决一些平台对视频时长的要求,最好有自动处理的工具!
  • ¥15 累加器设初值为00H
  • ¥15 webAPI接口返回值判断
  • ¥15 自动化测试 UI Automtion
  • ¥20 关于#深度学习#的问题:2708)输出:邻接矩阵A 或者 节点索引方式:通过随机游走或者其他方式,保持节点连接类似下图(语言-python)
  • ¥15 win11 24h2 专业工作站版 右键打印怎样删除