mysql去重怎么用窗口函数_mysql使用窗口函数去重方法介绍

admin 百科 8
使用ROW_NUMBER()窗口函数可高效去重,通过PARTITION BY分组、ORDER BY排序,筛选rn=1保留每组首行,如按user_id保留最早订单;调整ORDER BY可保留最新或最高金额记录;相比DISTINCT和GROUP BY,窗口函数更灵活精准,支持复杂业务逻辑。

mysql去重怎么用窗口函数_mysql使用窗口函数去重方法介绍-第1张图片-佛山资讯网

在MySQL中,使用窗口函数去重是一种高效且灵活的方法,尤其适用于需要保留某些排序规则或额外信息的场景。相比传统的 DISTINCTGROUP BY,窗口函数可以更精细地控制哪些重复数据被保留。

使用 ROW_NUMBER() 窗口函数去重

最常用的窗口函数去重方式是结合 ROW_NUMBER() 和子查询,为每组重复数据分配行号,然后筛选出第一行。

例如,有一张用户订单表 user_orders,结构如下:

user_id, order_date, amount

如果想根据 user_id 去重,只保留每个用户的第一条订单记录,可以这样写:

SELECT *
FROM (
    SELECT *,
           ROW_NUMBER() OVER (PARTITION BY user_id ORDER BY order_date) AS rn
    FROM user_orders
) t
WHERE rn = 1;

登录后复制

这里 PARTITION BY user_id 表示按用户分组,ORDER BY order_date 决定组内排序,ROW_NUMBER() 为每行分配一个序号,取 rn = 1 即可保留最早的一条记录。

根据条件选择保留最新或最高优先级记录

去重时不一定非要保留第一条,可以根据业务需求调整 ORDER BY 子句。

标签: mysql去重 mysql

发布评论 0条评论)

还木有评论哦,快来抢沙发吧~