10个SQL技巧之三:进行总计算

栏目: 数据库 · 发布时间: 7年前

内容简介:至少有十几种方法可以实现运行总计。从概念上讲,运行总计很容易理解。在Microsoft Excel中,您只需计算两个先前(或后续)值的总和(或差异),然后使用有用的十字光标在整个电子表格中提取该公式。您通过电子表格“运行”该总计。一个“运行总数”。在SQL中,最好的方法是使用Window窗口函数是一个强大的概念 - 起初不是那么容易理解,但实际上,它们真的很容易:

至少有十几种方法可以实现运行总计。从概念上讲,运行总计很容易理解。在Microsoft Excel中,您只需计算两个先前(或后续)值的总和(或差异),然后使用有用的十字光标在整个电子表格中提取该公式。您通过电子表格“运行”该总计。一个“运行总数”。

SQL 中,最好的方法是使用 窗口 [url=https://blog.jooq.org/tag/window-functions]函数[/url]。

Window窗口函数是一个强大的概念 - 起初不是那么容易理解,但实际上,它们真的很容易:

窗口函数是相对于SELECT转换的当前行的行子集的聚合/排名

它本质上意味着窗口函数可以对当前行“上方”或“下方”的行执行计算。与GROUP BY普通聚合不同,它们不会对行进行转换,这使得它们非常有用。

语法可以总结如下,单个部分是可选的

function(...) OVER (
  PARTITION BY ...
  ORDER BY ...
  ROWS BETWEEN ... AND ...
)

所以,我们有任何类型的函数(我们稍后会看到这些函数的例子),然后是OVER()子句,它指定了窗口。即OVER()条款定义:

  • PARTITION:只有在相同分区的行作为当前行会被认为是窗口
  • ORDER:该窗口可以独立 排序 的,排序取决于我们要Select的是什么
  • ROWS(或RANGE)帧定义:窗口可以限制到“超前”和“后面”的固定数目的行数

这就是窗口功能。

现在,这有助于我们计算一个总计?请考虑以下数据:

| ID   | VALUE_DATE | AMOUNT |    BALANCE |
|------|------------|--------|------------|
| 9997 | 2014-03-18 |  99.17 |   19985.81 |
| 9981 | 2014-03-16 |  71.44 |   19886.64 |
| 9979 | 2014-03-16 | -94.60 |   19815.20 |
| 9977 | 2014-03-16 |  -6.96 |   19909.80 |
| 9971 | 2014-03-15 | -65.95 |   19916.76 |

我们假设BALANCE是我们想要从AMOUNT计算的,因此,用简单的英语,任何余额都可以用以下伪SQL表示:

TOP_BALANCE – SUM(AMOUNT) OVER (“all the rows on top of the current row”)

在真正的SQL中,那将写成如下:

SUM(t.amount) OVER (
  PARTITION BY t.account_id 
  ORDER BY     t.value_date DESC,
               t.id         DESC
  ROWS BETWEEN UNBOUNDED PRECEDING
       AND     1         PRECEDING
)

说明:

  • 分区将计算每个银行帐户的总和,而不是整个数据集
  • 排序将保证在求和之前(在分区内)对事务进行排序
  • 在汇总之前,rows子句将仅考虑前面的行(在分区内,给定排序)

所有这些都将在内存中发生,在您已经在FROM .. WHERE等子句中选择的数据集中,因此非常快。


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

Web信息架构(第3版)

Web信息架构(第3版)

[美] Peter Morville、Louis Rosenfeld / 陈建勋 / 电子工业出版社 / 2013-10 / 99.00元

本书内容涵盖了信息架构基本原理和实践应用的方方面面。全书共7个部分,包括信息架构概述、信息架构的基本原理、信息架构的开发流程和方法论、信息架构实践、信息架构与组织、两个案例研究,以及参考资料清单。 本书兼具较高的理论价值和实用价值,曾被Web设计领域多本书籍重点推荐,是信息架构领域公认的经典书籍,不论新手还是专家都能各取所需。本书可供Web设计与开发者、Web架构师、网站管理者及信息管理相关......一起来看看 《Web信息架构(第3版)》 这本书的介绍吧!

JS 压缩/解压工具
JS 压缩/解压工具

在线压缩/解压 JS 代码

JSON 在线解析
JSON 在线解析

在线 JSON 格式化工具

XML 在线格式化
XML 在线格式化

在线 XML 格式化压缩工具