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 office打开卡退(新电脑重装office系统后)
  • ¥300 FLUENT 火箭发动机燃烧EDC仿真
  • ¥15 【Hadoop 问题】Hadoop编译所遇问题hadoop-common: make failed with error code 2
  • ¥15 vb6.0+webbrowser无法加载某个网页求解
  • ¥15 RPA财务机器人采购付款流程
  • ¥15 计算机图形多边形及三次样条曲线绘制
  • ¥15 根据protues画的图用keil写程序
  • ¥200 如何使用postGis实现最短领规划?
  • ¥15 pyinstaller打包错误
  • ¥20 cesm的气溶胶排放文件