SQL 窗口函数简介

窗口函数对一组行进行操作,并为基础查询中的每一行返回一个值。 术语窗口描述了函数在其上进行操作的行集。 窗口函数使用窗口中各行的值来计算返回的值。
摘要由CSDN通过智能技术生成

SQL 窗口函数简介

原文地址 | 译文地址

窗口函数对一组行进行操作,并为基础查询中的每一行返回一个值。 术语窗口描述了函数在其上进行操作的行集。 窗口函数使用窗口中各行的值来计算返回的值。
在查询中使用窗口函数时,请使用OVER()子句定义窗口。 OVER()子句(窗口定义)将窗口函数与其他分析和报告函数区分开。 一个查询可以包含具有相同或不同窗口定义的多个窗口函数。
OVER()子句具有以下功能:

  • 定义窗口分区以形成行组。 (PARTITION BY子句)
  • 对分区内的行进行排序。 (ORDER BY子句)
    例如,以下查询使用AVG()窗口函数来计算第一季度员工的平均销售额:
  select emp_name, dealer_id, sales, avg(sales) over() as avgsales from q1_sales;
   +-----------------+------------+--------+-----------+
   |    emp_name     | dealer_id  | sales  | avgsales  |
   +-----------------+------------+--------+-----------+
   | Beverly Lang    | 2          | 16233  | 13631     |
   | Kameko French   | 2          | 16233  | 13631     |
   | Ursa George     | 3          | 15427  | 13631     |
   | Ferris Brown    | 1          | 19745  | 13631     |
   | Noel Meyer      | 1          | 19745  | 13631     |
   | Abel Kim        | 3          | 12369  | 13631     |
   | Raphael Hull    | 1          | 8227   | 13631     |
   | Jack Salazar    | 1          | 9710   | 13631     |
   | May Stout       | 3          | 9308   | 13631     |
   | Haviva Montoya  | 2          | 9308   | 13631     |
   +-----------------+------------+--------+-----------+
   10 rows selected (0.213 seconds)

AVG()窗口函数对窗口中定义的行进行操作,并为每行返回一个值。 为了进行比较,您可以使用AVG()函数作为标准集合函数来运行查询:

   select avg(sales) as avgsales from q1_sales;
   +-----------+
   | avgsales  |
   +-----------+
   | 13630.5   |
   +-----------+
   1 row selected (0.131 seconds)

查询将返回指定列中所有值的平均值的一行,而不是返回每一行的值。
您还可以在查询中包括可选的PARTITION BY和ORDER BY子句。 PARTITION BY子句将窗口细分为多个分区。 ORDER BY子句定义结果集每个分区内的行的逻辑顺序。 窗口函数将应用于每个分区内的行,并根据顺序规范进行排序。
以下查询将AVG()窗口函数与PARTITION BY子句一起使用,以确定第一季度每个经销商的平均汽车销售量:

   select emp_name, dealer_id, sales, avg(sales) over (partition by dealer_id) as avgsales from q1_sales;
   +-----------------+------------+--------+-----------+
   |    emp_name     | dealer_id  | sales  | avgsales  |
   +-----------------+------------+--------+-----------+
   | Ferris Brown    | 1          | 19745  | 14357     |
   | Noel Meyer      | 1          | 19745  | 14357     |
   | Raphael Hull    | 1          | 8227   | 14357     |
   | Jack Salazar    | 1          | 9710   | 14357     |
   | Beverly Lang    | 2          | 16233  | 13925     |
   | Kameko French   | 2         
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

张知文

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值