提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:王香|2018-12-14 09:46:07.000|阅读 224 次
概述:在本文我们将讨论用于形成值的函数本身。
# 慧都年终大促·界面/图表报表/文档/IDE等千款热门软控件火热促销中 >>
相关链接:
在本文的第二部分,我们将讨论用于形成值的函数本身。窗口函数根据与当前行关联的一组数据计算值,即,如果使用分区依据,则来自同一组的数据。用于 分组的常规聚合函数需要对行进行分组,从而从样本中丢失必要的唯一信息。因此,有必要使用两个而不是单个请求,以便拥有所有必要的数据和按组的总和。窗口聚合函数允许在一个查询 中实现相同的结果。窗口是一组用于计算函数的线。OVER指令将整个行集拆分为单独的组 - 根据指定条件的窗口。 我们来谈谈窗口函数的类型。有三组目的地:
为了演示函数的工作原理,我将使用一个简单的表:
CREATE TABLE ForWindowFunc (ID INT, GroupId INT, Amount INT) GO INSERT INTO ForWindowFunc (ID, GroupId, Amount) VALUES(1, 1, 100), (1, 1, 200), (1, 2, 150), (2, 1, 100), (2, 1, 300), (2, 2, 200), (2, 2, 50), (3, 1, 150), (3, 2, 200), (3, 2, 10);
SUM()函数就像常规聚合函数一样 - 它汇总了数据集中给定列的所有值。但是,由于OVER()指令,我们将数据集分解为窗口。根据ORDER BY子句中指定的顺序在窗口内执行求和。让我们看一个简 单的例子 - 三组的总和。
SELECT ID, Amount, SUM(Amount) OVER (ORDER BY id) AS SUM FROM ForWindowFunc
为方便起见,窗户以不同颜色突出显示。窗口中的所有值都具有相同的金额 - 窗口中所有金额的总和。
让我们在选择中添加另一列并更改OVER指令:
SELECT ID, GroupId, Amount, SUM(Amount) OVER (Partition BY id ORDER BY id, GroupId) AS SUM FROM ForWindowFunc
如您所见,由于GroupId字段,现在每个窗口都被分成组。现在每个小组都有自己的金额。 现在,让我们在每个窗口中创建一个累积结果:
SELECT ID, GroupId, Amount, SUM(Amount) OVER (Partition BY id ORDER BY id, GroupId, Amount) AS SUM FROM ForWindowFunc
我们不再需要GroupId字段,因此我们将其从选择中删除。现在,对于窗口中的每一行,计算总计,即金额的当前值与之前所有金额的总和。
此函数计算平均值。它可以与句子Partition by和Order by一起使用。
SELECT ID, Amount, AVG(Amount) OVER (Partition BY id ORDER BY id) AS AVG FROM ForWindowFunc
窗口中的每一行都有一个平均值Amount,它由公式计算:所有Amount /为行数的总和。 此函数的行为类似于SUM()。
从函数的名称可以清楚地看到它返回窗口中的最小值。
SELECT ID, Amount, MIN(Amount) OVER (Partition BY id ORDER BY id) AS MIN FROM ForWindowFunc
如您所见,在Min列中,窗口中显示最小Amount值。
MAX函数的工作方式与MIN相同,它只给出窗口中字段的最大值:
SELECT ID, Amount, MAX(Amount) OVER (Partition BY id ORDER BY id) AS MAX FROM ForWindowFunc
一切都很清楚。在第一组中,最大金额为200,第二组为300,第三组为200。
此函数返回窗口中的行数。
SELECT ID, Amount, COUNT(Amount) OVER (Partition BY id ORDER BY id) AS COUNT FROM ForWindowFunc
使查询更复杂一点,并添加GroupId字段。
SELECT ID, GroupId, Amount, COUNT(Amount) OVER (Partition BY id ORDER BY id, GroupId) AS COUNT FROM ForWindowFunc
在这种情况下,它更有趣。我们来看看第一个窗口。对于第一行和第二行,记录数为2.但对于第三行,该值已经为3.我们设法累积了累计金额等组中的金额。 如果我们仍然需要每个组中的数字, 则需要将GroupId添加到Partition by子句中。
SELECT ID, GroupId, Amount, COUNT(Amount) OVER (Partition BY id, GroupId) AS COUNT FROM ForWindowFunc
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@pclwef.cn
本文探讨 SQL Server 中 NULL 和空值之间的区别,并讨论如何有效地处理它们。
Unity 是一款功能极其丰富的游戏引擎,允许开发人员将各种媒体集成到他们的项目中。但是,它缺少最令人兴奋的功能之一 - 将 Web 内容(例如 HTML、CSS 和 JavaScript)直接渲染到 3D 场景中的纹理上的能力。在本文中,我们将介绍如何使用 DotNetBrowser 在 Unity3D 中将 Web 内容渲染为纹理。
DevExpress v24.2帮助文档正式发布上线了,请按版本按需下载~
本教程将向您展示如何用MyEclipse构建一个Web项目,欢迎下载最新版IDE体验!
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@pclwef.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢