3

这是我想在 Greenplum 数据库中完成的非常基本的查询(如 postgresql 8.2.15)。

表 t 中的字段 create_date 是不带时区的时间戳。谁能指出我正确的查询来完成这个?谢谢。

select * from generate_series ((select EXTRACT (YEAR FROM MIN(t1.create_date)) from t1),(select EXTRACT (YEAR FROM MAX(t1.create_date)) from t1))

它的投掷错误

ERROR:  function generate_series(double precision, double precision) does not exist

第 1 行:select * from generate_series ((select EXTRACT (YEAR FROM MI... ^ 提示:没有函数匹配给定的名称和参数类型。您可能需要添加显式类型转换。

4

1 回答 1

4

您可以将参数显式转换为整数:

select *
from generate_series (
    (select EXTRACT (YEAR FROM MIN(t1.create_date)) from t1)::int,
    (select EXTRACT (YEAR FROM MAX(t1.create_date)) from t1)::int
)

sql fiddle demo

于 2013-11-15T20:32:07.620 回答