MySQL 8.0 版本开始支持窗口函数,可以使用 OVER 子句实现开窗函数。
窗口函数是在行集合内执行的聚合函数,返回一个结果集,其中每一行都包含来自查询中特定行的值。窗口函数与 GROUP BY 子句不同,在 GROUP BY 子句中,查询的结果集被分组为单个行,而在窗口函数中,查询的结果集被分为多个行,每个行都包含其它数据并按照窗口定义进行排序。
下面是一个简单的示例,查询订单表中每个客户的销售总额和排名:
SELECT
customer_id,
SUM(amount) AS total_sales,
RANK() OVER (ORDER BY SUM(amount) DESC) AS sales_rank
FROM
orders
GROUP BY
customer_id;
在上面的查询中,RANK() 是窗口函数,用于计算每个客户的销售总额排名。OVER 子句指定了排序顺序,这里按照销售总额降序排序。GROUP BY 子句用于将结果集按客户 ID 分组。
MySQL 支持的窗口函数包括 ROW_NUMBER、RANK、DENSE_RANK、NTILE、LAG、LEAD、FIRST_VALUE、LAST_VALUE 和 NTH_VALUE。可以通过 OVER 子句来指定窗口函数的排序方式、分区方式等。