[{"id":"1b88a165-2563-437e-99bb-ae30bd4b56db","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"a244ead7-a2c6-47a3-ac17-c5dbfa337362","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"33638a1c-7196-42c1-a96d-38b2d9ba8ac4","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"8e72e33e-b4ab-4fb3-98fc-a0b148134aed","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"86662220-9b9e-4940-9ced-d22642ea49a8","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"55fd3bb8-18d4-4edb-9640-ca3a365b798f","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"760b37c7-c713-4b24-b9ba-4bfe7d8437a6","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"3a083583-1d5f-492b-b450-34b2b5c775b8","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"04e73782-aa78-4dfe-a4f9-e72ed4c78a11","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"57c94653-8893-403b-a5b1-0d1e33a0bd0f","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"09a66339-64c0-415c-b142-0691587a8e4a","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"5b7aeac5-c755-426a-95c7-1ae8e547179a","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"790bc77a-9216-48fd-b8f9-fbc374ebb155","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"900e6cab-065d-4f1c-844d-efa3c074e270","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"0baaf91d-84f6-404c-a487-735226b6d5b6","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"5d37413b-3600-4da9-9700-feea54355f59","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"7ded3a22-15eb-49b8-a488-e83c2cd872eb","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"89c707ed-9841-4e53-96fb-940cc3214804","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"a570c8e7-07a2-47da-965b-da44fd1fa5cf","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"a5a73576-16ea-4cbc-925c-ef547389eaa5","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"69e79655-e015-4f9a-a230-2a25c988c926","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"adf3817f-7667-4a4c-8a5f-767b0b7e1e3e","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"1126cfab-6210-4e28-bee0-02c113fb7a0c","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"63c577e6-6cf9-497e-94e1-2307f7d3f498","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"24769ecd-2b08-4a85-b318-4f533bbf8393","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"2605431b-dc80-491d-886e-28981595d277","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]},{"id":"4f41e22e-eb51-49e5-aeae-a42dd6bf352c","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"aa71a884-c5bc-4842-8d6a-873dfd645167","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"b0576ca2-cb84-4390-9f95-9354ec20eda5","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"dacc7931-6785-4675-be31-80930403cf7b","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"c90d5fdf-420f-4978-8bf5-c9a2bb4334b3","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"6e6ac5b1-1501-4e28-89cc-525139488537","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"ff052704-1389-4029-bcdd-73c6cbe9f807","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"21c6131f-0f2d-41d1-9284-6ad9ee803c1f","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"64e2f4a3-2303-4bfa-8a93-6c23ef01de58","tags":[{"name":"新增","color":"DarkGreen","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"9e117e35-984a-4c14-95ca-ef0ec7b9fb60"}]},{"id":"4a0842a3-20b1-40c3-8e00-cd5941ffdf53","tags":[{"name":"更新","color":"Coral","productId":"098be112-50ec-44e4-b746-6bc8bf76af97","links":null,"id":"a2f84374-4a3f-4d22-96fd-765e9de495bf"}]}]
        
(Showing Draft Content)

Window 函数

WINDOW 函数(v16.2)提供了一组在集算表中进行数据分析的函数。这些函数在与当前行相关的窗口(一组表格行)上进行计算,并生成一个列来显示结果。进行函数求值的行被称为当前行。

WINDOW 函数在特定窗口上执行聚合、排名和分析函数,并为每一行生成一个结果。

备注:

  • WINDOW 函数的结果可能会对集算表的行顺序产生影响。如果集算表已经排序或分组,结果将保持不变。

  • 当集算表的层级数据中存在树形结构时,WINDOW 函数无效。

  • 集算表的筛选器在 WINDOW 函数求值后执行,并且仅筛选特定的行。

WINDOW只能与window函数一起使用。默认情况下,它将整个行视为一个窗口。

语法

WINDOW(window_function, [partitionby_function], [orderby_function], [frame_function])

参数

该函数具有以下参数:

参数

描述

window_function

[必需] 窗口函数。

[partitionby_function]

[可选] 将行分成分区。

[orderby_function]

[可选] 定义每个分区内行的逻辑顺序。

[frame_function]

[可选] 指定开始和结束点,将行组合到相对于当前行的分区内的窗口中。

WINDOW

WINDOW函数在应用相关的窗口函数之前确定分区、排序和限制窗口。

WINDOW函数使用PARTITIONBY和ORDERBY参数改变行的顺序。

请注意,如果在视图中应用了多个WINDOW函数,则它们的PARTITIONBY和ORDERBY必须相同,因为整个行的顺序将由PARTITIONBY和ORDERBY参数重新排序。否则,整个行将显示来自最后一个应用的WINDOW的顺序。

示例

WINDOW(ROWNUMBER(), PARTITIONBY([country]))

要了解更多可用的窗口函数,请参阅窗口函数列表部分。

PARTITIONBY

PARTITIONBY函数按升序将行分成分区,并将窗口函数分别应用于每个分区。如果未指定PARTITIONBY,则整个行将被视为一个窗口。PARTITIONBY必须具有一个或多个字段名称或公式的列表达式。

语法

PARTITIONBY(field_function [, field_function [, ... ] ])

参数

该函数具有以下参数:

参数

描述

field_function

[必需] 要进行分区的字段名称或公式。

示例

WINDOW(SUM([Sales]), PARTITIONBY([Product], YEAR([@OrderDate])))

ORDERBY函数

ORDERBY函数定义了每个分区内行的逻辑顺序。它会影响指定的窗口和窗口函数的计算。ORDERBY必须具有一个或多个字段名称或公式的列表达式。

语法

ORDERBY(field_function [, field_function [, ... ] ])

参数

该函数具有以下参数:

参数

描述

field_function

[必需] 要进行排序的字段名称或公式。

您还可以使用ORDERASCORDERDESC以升序或降序方式对数据进行排序。默认情况下,排序顺序为ORDERASC,并且将NULL值视为最低值。

注意

  • 如果未指定 ORDERBY,则窗口函数将使用分区中等于 FRAMERANGE(-1, -1) 的所有行。

  • 如果指定了 ORDERBY 且未指定 FRAMEROWS/FRAMERANGE,则FRAMERANGE(-1, [@]) 将成为计算窗口函数的默认范围表达式。

语法

ORDERASC(field function)

ORDERDESC(field function)

示例

WINDOW(SUM([Sales]), ORDERBY([Product], ORDERDESC(QUARTER([@OrderDate]))))

FRAME

FRAME 函数指定开始和结束点,将行组合到相对于当前行的分区内的窗口中。窗口函数将使用由窗口指定的行集。窗口以开始、结束和当前行关闭。FRAME函数可以定义为FRAMEROWS或FRAMERANGE。

FRAMEROWS

FRAMEROWS 允许您通过指定当前行之前和之后的非负整数行数来限制窗口的行集。如果前面或后面的行数中有一个超出了当前分区的边界,将使用分区的起始或结束行。如果两者都在外部,将不返回任何行。

参数

接受的值

描述

第一个参数

指示当前行之前的行数。

-1, [@-n] 或 [@]

-1: 指示当前分区的边界。

n: 接受非负整数,表示行数。

[@]: 表示当前行的位置。

第二个参数

指示当前行之后的行数。

-1, [@+n] 或 [@

注意:如果FRAMEROWS函数中缺少第二个参数,则默认值为[@]。

语法

FRAMEROWS(preceding_function [, following_function ])

参数

该函数具有以下参数:

参数

描述

preceding_function

[必需] 当前行之前的行数。

[following_function]

[可选] 当前行之后的行数。

示例

WINDOW(SUM([Sales]), PARTITIONBY([Product], YEAR([@OrderDate])), ORDERBY(QUARTER([@OrderDate])), FRAMEROWS([@-1], [@]))

FRAMERANGE

FRAMERANGE通过指定非负数作为当前行由ORDERBY列组成的对等行周围的相同值的距离,来限制窗口的范围。FRAMERANGE函数有两个主要参数,每个参数表示当前行的对等行之前和之后的距离。

参数

接受的值

描述

第一个参数

指示当前行的对等行之前的距离。

-1, [@-n]

如果顺序是降序,则应使用[@+n],或[@]。

-1: 指示当前分区的边界。

n: 接受非负整数,表示距离。

[@]: 表示与当前行具有相同值的对等行。

第二个参数

指示当前行的对等行之后的距离。

-1, [@+n]

如果顺序是降序,则应使用[@-n],或[@]。

该框架范围是一个完全闭合的区间。它要求ORDERBY提供具有数值数据类型的第一列。但是,如果有多个排序列,只接受-1和[@]。

带 ORDERBY 的 FRAMERANGE

  • FRAMERANGE要求ORDERBY只提供一个具有数值数据类型的列,以检索当前行中的值,以找到[@]所对应的绑定行。

  • 如果删除ORDERBY,则默认帧表达式为FRAMERANGE(-1, -1),即使指定了FRAMERANGE。

  • 如果ORDERBY包含多列,则只能在FRAMERANGE中使用-1和[@],而[@-/+n]将默认为-1。当前捆绑行可以由组合列值定义。

带 NULL 的 FRAMERANGE

  • 如果排序列中的某些值为NULL,则具有NULL值的行将在分区内的顶部/底部并列排列。

  • 如果当前捆绑行的值为空,[@+/-n]将类似于[@+/-0],它等于[@]。

  • 如果当前捆绑行的值不为空,[@+/-n]的检索将停止到具有NULL值的行。

语法

FRAMERANGE(preceding_function [, following_function ])

参数

该函数具有以下参数:

参数

描述

preceding_function

[必需] 当前行之前的距离。

[following_function]

[可选] 当前行之后的距离。

示例

WINDOW(SUM([Sales]), PARTITIONBY([Product], YEAR([@OrderDate])), ORDERBY(QUARTER([@OrderDate])), FRAMERANGE([@-1], [@]))

以下图片展示了如何使用聚合窗口函数获取每个产品的移动平均销售额和销售额趋势。

WindowFunctions.bf5731