Mysql之GROUP BY与PARTITION BY区别

GROUP BY
GROUP BY 是一个SQL子句,用于将结果集按一个或多个列进行分组,然后对每个组应用聚合函数(如 SUM, COUNT, AVG 等)。它会改变查询的结果集,使其只包含每个组的汇总信息。

例如:

sql

SELECT employee_id, SUM(amount)
FROM sales
GROUP BY employee_id;

这个查询会返回每个 employee_id 对应的 amount 的总和。

PARTITION BY
PARTITION BY 是窗口函数的一部分,用于定义窗口(即数据分区),但是它不会改变结果集的行数。相反,它会在指定的窗口内计算聚合值或排名等,并将这些值附加到每一行中去。

例如:

sql

SELECT 
    employee_id,
    amount,
    SUM(amount) OVER (PARTITION BY employee_id) AS totalAmount
FROM 
    sales;

这个查询会返回每一行,并在每一行中增加一个列 totalAmount,它表示的是该 employee_id 内所有 amount 的总和。

区别
功能:GROUP BY 用于分组并返回每组的聚合结果。PARTITION BY 用于窗口函数内,将结果集划分为几个分区,计算聚合值或其他窗口函数。
结果集:GROUP BY 改变结果集的行数,只返回每组一行。PARTITION BY 不改变结果集的行数,而是在原始结果集中增加计算列。
例子对比
假设有一个表 sales:

employee_id	amount
1	100
1	150
2	200
2	250

使用 GROUP BY:

sql

SELECT employee_id, SUM(amount) AS totalAmount
FROM sales
GROUP BY employee_id;

结果:

employee_id	totalAmount
1	250
2	450

使用 PARTITION BY:

sql

SELECT 
    employee_id,
    amount,
    SUM(amount) OVER (PARTITION BY employee_id) AS totalAmount
FROM 
    sales;

结果:

employee_id	amount	totalAmount
1	100	250
1	150	250
2	200	450
2	250	450

总结:

GROUP BY 用于分组和聚合,改变结果集的结构。
PARTITION BY 用于窗口函数,增加计算列,不改变结果集的结构。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值