您的位置:首页 > 游戏 > 手游 > 中国网络游戏投诉平台_东莞阳光网招标平台_百度推广开户怎么开_宁波seo外包公司

中国网络游戏投诉平台_东莞阳光网招标平台_百度推广开户怎么开_宁波seo外包公司

2025/5/21 17:13:14 来源:https://blog.csdn.net/weixin_44665318/article/details/147634604  浏览:    关键词:中国网络游戏投诉平台_东莞阳光网招标平台_百度推广开户怎么开_宁波seo外包公司
中国网络游戏投诉平台_东莞阳光网招标平台_百度推广开户怎么开_宁波seo外包公司

使用语法

ROW_NUMBER() OVER ([PARTITION BY partition_column1, partition_column2, ...]ORDER BY sort_column1 [ASC|DESC], sort_column2 [ASC|DESC], ...
)
  • PARTITION BY:将数据按指定列分组,每组内单独生成行号。
  • ORDER BY:决定组内行号的排序依据。

适用场景

1. 分页查询

在需要对结果集分页且需要全局排序时,ROW_NUMBER() 可替代传统 LIMIT/OFFSET,尤其在复杂排序或嵌套查询中更高效。

SELECT *
FROM (SELECT ROW_NUMBER() OVER (ORDER BY create_time DESC) AS row_num,id, title, create_timeFROM articles
) AS tmp
WHERE row_num BETWEEN 11 AND 20; -- 获取第2页(每页10条)

2. 去重(保留每组最新/第一条记录)

当数据有重复时,按业务逻辑保留每组中的特定行(如最新记录)。

WITH ranked_data AS (SELECT id, user_id, order_date,ROW_NUMBER() OVER (PARTITION BY user_id ORDER BY order_date DESC) AS rnFROM orders
)
SELECT id, user_id, order_date
FROM ranked_data
WHERE rn = 1; -- 每个用户最近的一笔订单

3. 生成唯一排名(无并列排名)

即使值相同,ROW_NUMBER() 也会生成唯一序号(区别于 RANK() 和 DENSE_RANK())。

SELECT student_id, exam_score,ROW_NUMBER() OVER (ORDER BY exam_score DESC) AS rank
FROM exam_results; -- 分数相同的学生会得到不同排名

4. 分组分析(如时间序列处理)

按分区跟踪行号,用于分析组内趋势(如计算用户行为序列

SELECT user_id, event_time, event_type,ROW_NUMBER() OVER (PARTITION BY user_id ORDER BY event_time) AS action_seq
FROM user_events; -- 标记用户行为的顺序

注意事项:

去重替代方案:若仅需去重,可考虑 DISTINCTGROUP BY,但复杂逻辑仍需 ROW_NUMBER()。

版权声明:

本网仅为发布的内容提供存储空间,不对发表、转载的内容提供任何形式的保证。凡本网注明“来源:XXX网络”的作品,均转载自其它媒体,著作权归作者所有,商业转载请联系作者获得授权,非商业转载请注明出处。

我们尊重并感谢每一位作者,均已注明文章来源和作者。如因作品内容、版权或其它问题,请及时与我们联系,联系邮箱:809451989@qq.com,投稿邮箱:809451989@qq.com