Py学习  »  DATABASE

MySQL开窗函数

经管之家 • 1 年前 • 223 次点击  
Mysql开窗函数是8.0以上版本提供的新功能,对于数据分析非常方便好用。在求排序、占比等方面很强大。学员经常不太好理解,以下做些说明。
MySQL开窗函数是一种强大的SQL函数,用于在查询结果集中执行聚合、排序和分析操作。它提供了一种在查询结果中执行窗口操作的方法,例如计算排名、累计求和、移动平均等。本课程将介绍开窗函数的基本概念、常用的公式和注意事项,并提供一些实际应用的举例。
开窗函数的基本语法如下:
OVER (PARTITION BY ORDER BY )
  • 聚合函数:可以是SUM、AVG、COUNT等常见的聚合函数。
  • PARTITION BY:可选项,用于指定分组字段,将查询结果分组。
  • ORDER BY:可选项,用于指定排序字段,决定开窗函数的计算顺序。
  • 窗口范围:可选项,用于指定计算窗口的范围,例如ROWS BETWEEN UNBOUNDED PRECEDING AND CURRENT ROW。
注意事项:
  • 开窗函数只能在SELECT语句中使用,不能在WHERE或HAVING子句中使用。
  • 开窗函数的计算顺序是在聚合之后、排序之前。
  • 开窗函数可以用于计算排名、求和、平均值等,但不支持使用开窗函数的结果作为过滤条件。

攻略:

  • 确定使用开窗函数的目的和需求,选择合适的聚合函数和窗口范围。
  • 确定分组字段和排序字段,以及它们的顺序。
  • 熟悉常用的开窗函数公式和用法,例如RANK、SUM、ROW_NUMBER等。
  • 理解开窗函数的计算顺序和作用范围,避免误用和错误结果。
  • 在实际应用中,结合其他SQL语句和条件,灵活使用开窗函数,满足特定的查询需求。
应用举例:
  • 计算每个部门的销售额排名:
SELECT department, sales, RANK() OVER (PARTITION BY department ORDER BY sales DESC) AS rank  FROM sales_table;
  • 计算每个月的销售额累计求和:
SELECT month, sales, SUM(sales) OVER (ORDER BY month) AS cumulative_sum  FROM sales_table;
  • 计算每个销售人员的销售额占比:
SELECT salesperson, sales, sales / SUM(sales) OVER () AS sales_percentage  FROM sales_table;
总结:开窗函数是一种强大的工具,可以在查询结果集中执行聚合、排序和分析操作。通过灵活运用开窗函数,可以满足各种复杂的查询需求,并提高查询的效率和准确性。

扫码添加老师微信,了解更多内容:

Python社区是高质量的Python/Django开发社区
本文地址:http://www.python88.com/topic/160558
 
223 次点击