Windows 函数和分组依据

Posted

技术标签:

【中文标题】Windows 函数和分组依据【英文标题】:Windows Functions and Group By 【发布时间】:2020-06-12 02:03:35 【问题描述】:

我正在尝试运行此查询并收到 SQL 编译错误:[CAST(OV.TOTAL_VALUE AS NUMBER(25,5))] is not a valid group by expression

SELECT date_trunc('week', CREATED_AT) as WEEK, SUB_GROUP, AVG(TOTAL_VALUE) as AOV_VERTICAL, AVG(TOTAL_VALUE) OVER (PARTITION BY date_trunc('week', CREATED_AT))
FROM OV
GROUP BY 1,2

我有一个包含日期、子组和总值的表格,我想要一个按周和 sub_group 显示平均总值的表格,以及按周显示平均值的第二列。

我正在使用雪花。

谢谢!

【问题讨论】:

一些样本数据和期望的结果会明确你想要什么。 【参考方案1】:

如果你想要整体平均,你可以使用窗口函数:

SELECT date_trunc('week', CREATED_AT) as WEEK, SUB_GROUP,
       AVG(TOTAL_VALUE) as AOV_VERTICAL,
       SUM(SUM(TOTAL_VALUE)) / SUM(COUNT(*)) as overall_avg
FROM OV
GROUP BY 1,2

【讨论】:

以上是关于Windows 函数和分组依据的主要内容,如果未能解决你的问题,请参考以下文章

r 将函数应用于.SDcols和分组依据

JPA NamedQuery 与聚合函数和分组依据一起使用

Windows系统调用中API的3环部分(依据分析重写ReadProcessMemory函数)

按列分组并计算百分比,windows函数分区

具有分组依据的 PostgreSQL 聚合函数

没有分组依据的 MAX 函数