2

我正在使用 PostgreSQL 9.1.9。

在我正在处理的项目中,一些最近的记录具有空列,因为在创建该行时该信息不可用。我有一个视图列出了属于组成员的行的总和。截至目前,该视图显示最近列的总和,如果这些是最近的值,则使用空值。例如,

table1

group_name | member
-------------------
group1     | Andy
group1     | Bob

table2

name | stat_date | col1 | col2 | col 3
--------------------------------------
Andy | 6/19/13   | null |    1 |     2
Andy | 6/18/13   |  100 |    3 |     5
Bob  | 6/19/13   |   50 |    9 |    12
Bob  | 6/18/13   |  111 |   31 |    51

-- creating view would be something like this... 
create view v_grouped as 
select table1.group_name, stat_date, 
sum(col1) as col1_sum, sum(col2) as col2_sum, sum(col3) as col3_sum
from table1
join table2 on table1.member = table2.name
group by table1.group_name, table2.stat_date;

当前视图如下所示:

group_name | stat_date | col1_sum | col2_sum | col3_sum
-------------------------------------------------------
group1     | 6/19/13   |       50 |       10 |       14
group2     | 6/18/13   |      211 |       34 |       56

尽管缺乏 6/19 的数据,但 150 将更接近于实际组总数,而不是 50。所以,我想要一个输出

group_name | stat_date | col1_sum | col2_sum | col3_sum
-------------------------------------------------------
group1     |   6/19/13  |     150 |       10 |       14
group2     |   6/18/13  |     211 |       34 |       56

我一直在first_value()将窗口函数视为可能使用的函数。我发现甲骨文first_value()支持ignore nulls我相信会做我想做的事情(http://psoug.org/definition/FIRST_VALUE.htm)。根据我链接的这个页面,关于 PL/SQL 的first_value()功能:

如果结果集中的第一个值为 NULL,则函数返回 NULL,除非您指定 IGNORE NULLS。如果您使用 IGNORE NULLS 参数,则 FIRST_VALUE 将返回在结果集中找到的第一个非空值。(如果所有值都为空,那么它将返回 NULL。)

示例语法:FIRST_VALUE(expression [INGORE NULLS]) OVER (analytic_clause)

但是 PostgreSQLfirst_value()不支持这样的选项。有没有办法在 PostgreSql 中做到这一点?先感谢您!

4

2 回答 2

4

您可以使用this自定义聚合作为FIRST_VALUE(expression INGORE NULLS). 或者使用所需的行为构建您自己的聚合。

于 2013-07-03T20:55:41.413 回答
0

这是你要描述的吗?

SELECT sum(col1), sum(col2), sum(col3) FROM table2 WHERE col1 IS NOT NULL

(虽然我省略了 table1 上的连接;这是给读者的练习)

于 2013-07-03T20:05:11.250 回答