diff --git a/tsl/src/continuous_aggs/common.c b/tsl/src/continuous_aggs/common.c index 50b1b849164..a8ff51d65e5 100644 --- a/tsl/src/continuous_aggs/common.c +++ b/tsl/src/continuous_aggs/common.c @@ -17,7 +17,8 @@ static void caggtimebucketinfo_init(CAggTimebucketInfo *src, int32 hypertable_id Oid hypertable_partition_coltype, int64 hypertable_partition_col_interval, int32 parent_mat_hypertable_id); -static void process_additional_timebucket_parameter(ContinuousAggsBucketFunction *bf, Const *arg); +static void process_additional_timebucket_parameter(ContinuousAggsBucketFunction *bf, Const *arg, + bool *custom_origin); static void process_timebucket_parameters(FuncExpr *fe, ContinuousAggsBucketFunction *bf, bool process_checks, bool is_cagg_create, AttrNumber htpartcolno); @@ -181,7 +182,8 @@ destroy_union_query(Query *q) * Handle additional parameter of the timebucket function such as timezone, offset, or origin */ static void -process_additional_timebucket_parameter(ContinuousAggsBucketFunction *bf, Const *arg) +process_additional_timebucket_parameter(ContinuousAggsBucketFunction *bf, Const *arg, + bool *custom_origin) { char *tz_name; switch (exprType((Node *) arg)) @@ -204,16 +206,20 @@ process_additional_timebucket_parameter(ContinuousAggsBucketFunction *bf, Const break; case DATEOID: /* Bucket origin as Date */ - bf->bucket_time_origin = - date2timestamptz_opt_overflow(DatumGetDateADT(arg->constvalue), NULL); + if (!arg->constisnull) + bf->bucket_time_origin = + date2timestamptz_opt_overflow(DatumGetDateADT(arg->constvalue), NULL); + *custom_origin = true; break; case TIMESTAMPOID: /* Bucket origin as Timestamp */ bf->bucket_time_origin = DatumGetTimestamp(arg->constvalue); + *custom_origin = true; break; case TIMESTAMPTZOID: /* Bucket origin as TimestampTZ */ bf->bucket_time_origin = DatumGetTimestampTz(arg->constvalue); + *custom_origin = true; break; case INT2OID: /* Bucket offset as smallint */ @@ -248,10 +254,12 @@ process_timebucket_parameters(FuncExpr *fe, ContinuousAggsBucketFunction *bf, bo Node *width_arg; Node *col_arg; bool custom_origin = false; - Const *const_arg; + TIMESTAMP_NOBEGIN(bf->bucket_time_origin); + int nargs; /* Only column allowed : time_bucket('1day', ) */ col_arg = lsecond(fe->args); + /* Could be a named argument */ if (IsA(col_arg, NamedArgExpr)) col_arg = (Node *) castNode(NamedArgExpr, col_arg)->arg; @@ -263,75 +271,52 @@ process_timebucket_parameters(FuncExpr *fe, ContinuousAggsBucketFunction *bf, bo errmsg("time bucket function must reference the primary hypertable " "dimension column"))); - if (list_length(fe->args) >= 3) + nargs = list_length(fe->args); + Assert(nargs >= 2 && nargs <= 5); + + /* + * Process the third argument of the time bucket function. This could be `timezone`, `offset`, + * or `origin`. + * + * Time bucket function variations with 3 and 5 arguments: + * - time_bucket(width SMALLINT, ts SMALLINT, offset SMALLINT) + * - time_bucket(width INTEGER, ts INTEGER, offset INTEGER) + * - time_bucket(width BIGINT, ts BIGINT, offset BIGINT) + * - time_bucket(width INTERVAL, ts DATE, offset INTERVAL) + * - time_bucket(width INTERVAL, ts DATE, origin DATE) + * - time_bucket(width INTERVAL, ts TIMESTAMPTZ, offset INTERVAL) + * - time_bucket(width INTERVAL, ts TIMESTAMPTZ, origin TIMESTAMPTZ) + * - time_bucket(width INTERVAL, ts TIMESTAMPTZ, timezone TEXT, origin TIMESTAMPTZ, + * offset INTERVAL) + * - time_bucket(width INTERVAL, ts TIMESTAMP, offset INTERVAL) + * - time_bucket(width INTERVAL, ts TIMESTAMP, origin TIMESTAMP) + */ + if (nargs >= 3) { Const *arg = check_time_bucket_argument(lthird(fe->args), "third", process_checks); - process_additional_timebucket_parameter(bf, arg); + process_additional_timebucket_parameter(bf, arg, &custom_origin); } - if (list_length(fe->args) >= 4) + /* + * Process the fourth and fifth arguments of the time bucket function. This could be `origin` or + * `offset`. + * + * Time bucket function variation with 5 arguments: + * - time_bucket(width INTERVAL, ts TIMESTAMPTZ, timezone TEXT, origin TIMESTAMPTZ, + * offset INTERVAL) + */ + if (nargs >= 4) { Const *arg = check_time_bucket_argument(lfourth(fe->args), "fourth", process_checks); - process_additional_timebucket_parameter(bf, arg); + process_additional_timebucket_parameter(bf, arg, &custom_origin); } - /* Check for custom origin. */ - switch (exprType(col_arg)) + if (nargs == 5) { - case DATEOID: - /* Origin is always 3rd arg for date variants. */ - if (list_length(fe->args) == 3 && exprType(lthird(fe->args)) == DATEOID) - { - Node *arg = lthird(fe->args); - custom_origin = true; - /* this function also takes care of named arguments */ - const_arg = check_time_bucket_argument(arg, "third", process_checks); - bf->bucket_time_origin = - DatumGetTimestamp(DirectFunctionCall1(date_timestamp, const_arg->constvalue)); - } - break; - case TIMESTAMPOID: - /* Origin is always 3rd arg for timestamp variants. */ - if (list_length(fe->args) == 3 && exprType(lthird(fe->args)) == TIMESTAMPOID) - { - Node *arg = lthird(fe->args); - custom_origin = true; - const_arg = check_time_bucket_argument(arg, "third", process_checks); - bf->bucket_time_origin = DatumGetTimestamp(const_arg->constvalue); - } - break; - case TIMESTAMPTZOID: - /* Origin can be 3rd or 4th arg for timestamptz variants. */ - if (list_length(fe->args) >= 3 && exprType(lthird(fe->args)) == TIMESTAMPTZOID) - { - Node *arg = lthird(fe->args); - custom_origin = true; - Const *constval = check_time_bucket_argument(arg, "third", process_checks); - bf->bucket_time_origin = DatumGetTimestampTz(constval->constvalue); - } - else if (list_length(fe->args) >= 4 && exprType(lfourth(fe->args)) == TIMESTAMPTZOID) - { - custom_origin = true; - if (IsA(lfourth(fe->args), Const)) - { - bf->bucket_time_origin = - DatumGetTimestampTz(castNode(Const, lfourth(fe->args))->constvalue); - } - /* could happen in a statement like time_bucket('1h', .., 'utc', origin => - * ...) */ - else if (IsA(lfourth(fe->args), NamedArgExpr)) - { - Const *constval = - check_time_bucket_argument(lfourth(fe->args), "fourth", process_checks); - - bf->bucket_time_origin = DatumGetTimestampTz(constval->constvalue); - } - } - break; - default: - /* Nothing to do for integer time column. */ - break; + Const *arg = check_time_bucket_argument(lfifth(fe->args), "fifth", process_checks); + process_additional_timebucket_parameter(bf, arg, &custom_origin); } + if (process_checks && custom_origin && TIMESTAMP_NOT_FINITE(bf->bucket_time_origin)) { ereport(ERROR, diff --git a/tsl/test/expected/cagg_migrate_function-14.out b/tsl/test/expected/cagg_migrate_function-14.out index e9f4a249a3a..7b0dbbe87d7 100644 --- a/tsl/test/expected/cagg_migrate_function-14.out +++ b/tsl/test/expected/cagg_migrate_function-14.out @@ -170,7 +170,7 @@ SELECT mat_hypertable_id, SELECT * FROM _timescaledb_catalog.continuous_aggs_bucket_function WHERE mat_hypertable_id = :mat_hypertable_id; mat_hypertable_id | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width -------------------+-----------------------------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - 5 | timescaledb_experimental.time_bucket_ng(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Fri Jan 03 16:00:00 2020 PST | | | t + 5 | timescaledb_experimental.time_bucket_ng(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Sat Jan 04 00:00:00 2020 PST | | | t (1 row) SELECT pg_get_viewdef(:'partial_view', true); @@ -206,7 +206,7 @@ CALL _timescaledb_functions.cagg_migrate_to_time_bucket(:'CAGG_NAME'); SELECT * FROM _timescaledb_catalog.continuous_aggs_bucket_function WHERE mat_hypertable_id = :mat_hypertable_id; mat_hypertable_id | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width -------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - 5 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Fri Jan 03 16:00:00 2020 PST | | | t + 5 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Sat Jan 04 00:00:00 2020 PST | | | t (1 row) SELECT pg_get_viewdef(:'partial_view', true); diff --git a/tsl/test/expected/cagg_migrate_function-15.out b/tsl/test/expected/cagg_migrate_function-15.out index e9f4a249a3a..7b0dbbe87d7 100644 --- a/tsl/test/expected/cagg_migrate_function-15.out +++ b/tsl/test/expected/cagg_migrate_function-15.out @@ -170,7 +170,7 @@ SELECT mat_hypertable_id, SELECT * FROM _timescaledb_catalog.continuous_aggs_bucket_function WHERE mat_hypertable_id = :mat_hypertable_id; mat_hypertable_id | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width -------------------+-----------------------------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - 5 | timescaledb_experimental.time_bucket_ng(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Fri Jan 03 16:00:00 2020 PST | | | t + 5 | timescaledb_experimental.time_bucket_ng(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Sat Jan 04 00:00:00 2020 PST | | | t (1 row) SELECT pg_get_viewdef(:'partial_view', true); @@ -206,7 +206,7 @@ CALL _timescaledb_functions.cagg_migrate_to_time_bucket(:'CAGG_NAME'); SELECT * FROM _timescaledb_catalog.continuous_aggs_bucket_function WHERE mat_hypertable_id = :mat_hypertable_id; mat_hypertable_id | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width -------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - 5 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Fri Jan 03 16:00:00 2020 PST | | | t + 5 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Sat Jan 04 00:00:00 2020 PST | | | t (1 row) SELECT pg_get_viewdef(:'partial_view', true); diff --git a/tsl/test/expected/cagg_migrate_function-16.out b/tsl/test/expected/cagg_migrate_function-16.out index a030ec05aeb..6ee4679a965 100644 --- a/tsl/test/expected/cagg_migrate_function-16.out +++ b/tsl/test/expected/cagg_migrate_function-16.out @@ -170,7 +170,7 @@ SELECT mat_hypertable_id, SELECT * FROM _timescaledb_catalog.continuous_aggs_bucket_function WHERE mat_hypertable_id = :mat_hypertable_id; mat_hypertable_id | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width -------------------+-----------------------------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - 5 | timescaledb_experimental.time_bucket_ng(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Fri Jan 03 16:00:00 2020 PST | | | t + 5 | timescaledb_experimental.time_bucket_ng(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Sat Jan 04 00:00:00 2020 PST | | | t (1 row) SELECT pg_get_viewdef(:'partial_view', true); @@ -206,7 +206,7 @@ CALL _timescaledb_functions.cagg_migrate_to_time_bucket(:'CAGG_NAME'); SELECT * FROM _timescaledb_catalog.continuous_aggs_bucket_function WHERE mat_hypertable_id = :mat_hypertable_id; mat_hypertable_id | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width -------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - 5 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Fri Jan 03 16:00:00 2020 PST | | | t + 5 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Sat Jan 04 00:00:00 2020 PST | | | t (1 row) SELECT pg_get_viewdef(:'partial_view', true); diff --git a/tsl/test/expected/cagg_migrate_function-17.out b/tsl/test/expected/cagg_migrate_function-17.out index a030ec05aeb..6ee4679a965 100644 --- a/tsl/test/expected/cagg_migrate_function-17.out +++ b/tsl/test/expected/cagg_migrate_function-17.out @@ -170,7 +170,7 @@ SELECT mat_hypertable_id, SELECT * FROM _timescaledb_catalog.continuous_aggs_bucket_function WHERE mat_hypertable_id = :mat_hypertable_id; mat_hypertable_id | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width -------------------+-----------------------------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - 5 | timescaledb_experimental.time_bucket_ng(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Fri Jan 03 16:00:00 2020 PST | | | t + 5 | timescaledb_experimental.time_bucket_ng(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Sat Jan 04 00:00:00 2020 PST | | | t (1 row) SELECT pg_get_viewdef(:'partial_view', true); @@ -206,7 +206,7 @@ CALL _timescaledb_functions.cagg_migrate_to_time_bucket(:'CAGG_NAME'); SELECT * FROM _timescaledb_catalog.continuous_aggs_bucket_function WHERE mat_hypertable_id = :mat_hypertable_id; mat_hypertable_id | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width -------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - 5 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Fri Jan 03 16:00:00 2020 PST | | | t + 5 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 7 days | Sat Jan 04 00:00:00 2020 PST | | | t (1 row) SELECT pg_get_viewdef(:'partial_view', true); diff --git a/tsl/test/expected/cagg_query-14.out b/tsl/test/expected/cagg_query-14.out index 4739c69f52f..6280ca364f8 100644 --- a/tsl/test/expected/cagg_query-14.out +++ b/tsl/test/expected/cagg_query-14.out @@ -1041,7 +1041,7 @@ psql:include/cagg_query_common.sql:483: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+--------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin; @@ -1055,7 +1055,7 @@ psql:include/cagg_query_common.sql:491: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin2'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+---------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin2; diff --git a/tsl/test/expected/cagg_query-15.out b/tsl/test/expected/cagg_query-15.out index 4739c69f52f..6280ca364f8 100644 --- a/tsl/test/expected/cagg_query-15.out +++ b/tsl/test/expected/cagg_query-15.out @@ -1041,7 +1041,7 @@ psql:include/cagg_query_common.sql:483: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+--------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin; @@ -1055,7 +1055,7 @@ psql:include/cagg_query_common.sql:491: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin2'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+---------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin2; diff --git a/tsl/test/expected/cagg_query-16.out b/tsl/test/expected/cagg_query-16.out index 84ddfb0b714..810f3f38fdc 100644 --- a/tsl/test/expected/cagg_query-16.out +++ b/tsl/test/expected/cagg_query-16.out @@ -1035,7 +1035,7 @@ psql:include/cagg_query_common.sql:483: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+--------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin; @@ -1049,7 +1049,7 @@ psql:include/cagg_query_common.sql:491: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin2'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+---------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin2; diff --git a/tsl/test/expected/cagg_query-17.out b/tsl/test/expected/cagg_query-17.out index 84ddfb0b714..810f3f38fdc 100644 --- a/tsl/test/expected/cagg_query-17.out +++ b/tsl/test/expected/cagg_query-17.out @@ -1035,7 +1035,7 @@ psql:include/cagg_query_common.sql:483: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+--------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin; @@ -1049,7 +1049,7 @@ psql:include/cagg_query_common.sql:491: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin2'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+---------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin2; diff --git a/tsl/test/expected/cagg_query_using_merge-15.out b/tsl/test/expected/cagg_query_using_merge-15.out index 682d3aaae4c..ad04ba4beb9 100644 --- a/tsl/test/expected/cagg_query_using_merge-15.out +++ b/tsl/test/expected/cagg_query_using_merge-15.out @@ -1043,7 +1043,7 @@ psql:include/cagg_query_common.sql:483: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+--------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin; @@ -1057,7 +1057,7 @@ psql:include/cagg_query_common.sql:491: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin2'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+---------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin2; diff --git a/tsl/test/expected/cagg_query_using_merge-16.out b/tsl/test/expected/cagg_query_using_merge-16.out index 71bf6d60a91..821c420e452 100644 --- a/tsl/test/expected/cagg_query_using_merge-16.out +++ b/tsl/test/expected/cagg_query_using_merge-16.out @@ -1037,7 +1037,7 @@ psql:include/cagg_query_common.sql:483: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+--------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin; @@ -1051,7 +1051,7 @@ psql:include/cagg_query_common.sql:491: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin2'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+---------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin2; diff --git a/tsl/test/expected/cagg_query_using_merge-17.out b/tsl/test/expected/cagg_query_using_merge-17.out index 71bf6d60a91..821c420e452 100644 --- a/tsl/test/expected/cagg_query_using_merge-17.out +++ b/tsl/test/expected/cagg_query_using_merge-17.out @@ -1037,7 +1037,7 @@ psql:include/cagg_query_common.sql:483: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+--------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin; @@ -1051,7 +1051,7 @@ psql:include/cagg_query_common.sql:491: NOTICE: refreshing continuous aggregate SELECT * FROM caggs_info WHERE user_view_name = 'cagg_4_hours_date_origin2'; user_view_schema | user_view_name | bucket_func | bucket_width | bucket_origin | bucket_offset | bucket_timezone | bucket_fixed_width ------------------+---------------------------+--------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- - public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Fri Dec 31 16:00:00 1999 PST | | | t + public | cagg_4_hours_date_origin2 | public.time_bucket(interval,pg_catalog.date,pg_catalog.date) | @ 4 days | Sat Jan 01 00:00:00 2000 PST | | | t (1 row) DROP MATERIALIZED VIEW cagg_4_hours_date_origin2; diff --git a/tsl/test/expected/cagg_utils.out b/tsl/test/expected/cagg_utils.out index 8ac4bf55243..9eee9ca0bf7 100644 --- a/tsl/test/expected/cagg_utils.out +++ b/tsl/test/expected/cagg_utils.out @@ -378,10 +378,10 @@ ORDER BY user_view_name; -----------------------------+---------------------------------------------------------------------------------------+--------------+------------------------------+---------------+-----------------+-------------------- integer_ht_cagg | time_bucket(integer,integer) | 1 | | | | t integer_ht_cagg_offset | time_bucket(integer,integer,integer) | 1 | | 10 | | t - temperature_4h | time_bucket(interval,timestamp without time zone) | @ 4 hours | Fri Dec 31 16:00:00 1999 PST | | | t - temperature_tz_4h | time_bucket(interval,timestamp with time zone) | @ 4 hours | Fri Dec 31 16:00:00 1999 PST | | | t - temperature_tz_4h_ts | time_bucket(interval,timestamp with time zone,text,timestamp with time zone,interval) | @ 4 hours | Fri Dec 31 16:00:00 1999 PST | | Europe/Berlin | f - temperature_tz_4h_ts_offset | time_bucket(interval,timestamp with time zone,text,timestamp with time zone,interval) | @ 4 hours | Fri Dec 31 16:00:00 1999 PST | @ 1 hour | Europe/Berlin | f + temperature_4h | time_bucket(interval,timestamp without time zone) | @ 4 hours | | | | t + temperature_tz_4h | time_bucket(interval,timestamp with time zone) | @ 4 hours | | | | t + temperature_tz_4h_ts | time_bucket(interval,timestamp with time zone,text,timestamp with time zone,interval) | @ 4 hours | | | Europe/Berlin | f + temperature_tz_4h_ts_offset | time_bucket(interval,timestamp with time zone,text,timestamp with time zone,interval) | @ 4 hours | | @ 1 hour | Europe/Berlin | f temperature_tz_4h_ts_origin | time_bucket(interval,timestamp with time zone,text,timestamp with time zone,interval) | @ 4 hours | Mon Jan 01 00:00:00 2001 PST | | Europe/Berlin | f (7 rows) diff --git a/tsl/test/sql/CMakeLists.txt b/tsl/test/sql/CMakeLists.txt index af050f455cf..2b3a007d7a2 100644 --- a/tsl/test/sql/CMakeLists.txt +++ b/tsl/test/sql/CMakeLists.txt @@ -168,9 +168,12 @@ if((${PG_VERSION_MAJOR} GREATER_EQUAL "15")) merge_compress.sql) endif() +if((${PG_VERSION_MAJOR} GREATER_EQUAL "15")) + list(APPEND TEST_TEMPLATES cagg_query_using_merge.sql.in) +endif() + if((${PG_VERSION_MAJOR} GREATER_EQUAL "16")) list(APPEND TEST_FILES cagg_planning.sql hypercore_parallel.sql) - list(APPEND TEST_TEMPLATES cagg_query_using_merge.sql.in) endif() if((${PG_VERSION_MAJOR} GREATER_EQUAL "17"))