From 6f10276e484b1ce98fa9d93f25e74d4aea1fc3b8 Mon Sep 17 00:00:00 2001 From: TracyZYJ <37072511+TracyZYJ@users.noreply.github.com> Date: Fri, 27 Sep 2024 11:10:54 +0800 Subject: [PATCH] feat(query): DATE_ADD Functions to support week as a unit (#16530) --- src/query/functions/src/scalars/datetime.rs | 33 +++++++++++++++++++ .../it/scalars/testdata/function_list.txt | 8 +++++ .../functions/02_0012_function_datetimes.test | 5 +++ 3 files changed, 46 insertions(+) diff --git a/src/query/functions/src/scalars/datetime.rs b/src/query/functions/src/scalars/datetime.rs index d3fe39689274..03c77d9c0192 100644 --- a/src/query/functions/src/scalars/datetime.rs +++ b/src/query/functions/src/scalars/datetime.rs @@ -916,6 +916,39 @@ macro_rules! impl_register_arith_functions { ), ); + registry.register_passthrough_nullable_2_arg::( + concat!($op, "_weeks"), + + |_, _, _| FunctionDomain::MayThrow, + vectorize_with_builder_2_arg::(|date, delta, builder, ctx| { + let delta = 7 * delta; + match AddDaysImpl::eval_date(date, $signed_wrapper!{delta}) { + Ok(t) => builder.push(t), + Err(e) => { + ctx.set_error(builder.len(), e); + builder.push(0); + }, + } + }), + ); + registry.register_passthrough_nullable_2_arg::( + concat!($op, "_weeks"), + + |_, _, _| FunctionDomain::MayThrow, + vectorize_with_builder_2_arg::( + |ts, delta, builder, ctx| { + let delta = 7 * delta; + match AddDaysImpl::eval_timestamp(ts, $signed_wrapper!{delta}) { + Ok(t) => builder.push(t), + Err(e) => { + ctx.set_error(builder.len(), e); + builder.push(0); + }, + } + }, + ), + ); + registry.register_passthrough_nullable_2_arg::( concat!($op, "_hours"), diff --git a/src/query/functions/tests/it/scalars/testdata/function_list.txt b/src/query/functions/tests/it/scalars/testdata/function_list.txt index 5f4c60400817..7dc2aa898d68 100644 --- a/src/query/functions/tests/it/scalars/testdata/function_list.txt +++ b/src/query/functions/tests/it/scalars/testdata/function_list.txt @@ -108,6 +108,10 @@ Functions overloads: 1 add_seconds(Date NULL, Int64 NULL) :: Timestamp NULL 2 add_seconds(Timestamp, Int64) :: Timestamp 3 add_seconds(Timestamp NULL, Int64 NULL) :: Timestamp NULL +0 add_weeks(Date, Int64) :: Date +1 add_weeks(Date NULL, Int64 NULL) :: Date NULL +2 add_weeks(Timestamp, Int64) :: Timestamp +3 add_weeks(Timestamp NULL, Int64 NULL) :: Timestamp NULL 0 add_years(Date, Int64) :: Date 1 add_years(Date NULL, Int64 NULL) :: Date NULL 2 add_years(Timestamp, Int64) :: Timestamp @@ -3686,6 +3690,10 @@ Functions overloads: 1 subtract_seconds(Date NULL, Int64 NULL) :: Timestamp NULL 2 subtract_seconds(Timestamp, Int64) :: Timestamp 3 subtract_seconds(Timestamp NULL, Int64 NULL) :: Timestamp NULL +0 subtract_weeks(Date, Int64) :: Date +1 subtract_weeks(Date NULL, Int64 NULL) :: Date NULL +2 subtract_weeks(Timestamp, Int64) :: Timestamp +3 subtract_weeks(Timestamp NULL, Int64 NULL) :: Timestamp NULL 0 subtract_years(Date, Int64) :: Date 1 subtract_years(Date NULL, Int64 NULL) :: Date NULL 2 subtract_years(Timestamp, Int64) :: Timestamp diff --git a/tests/sqllogictests/suites/query/functions/02_0012_function_datetimes.test b/tests/sqllogictests/suites/query/functions/02_0012_function_datetimes.test index 5d82edc94527..ad73c54ddff0 100644 --- a/tests/sqllogictests/suites/query/functions/02_0012_function_datetimes.test +++ b/tests/sqllogictests/suites/query/functions/02_0012_function_datetimes.test @@ -1132,3 +1132,8 @@ query T select to_timestamp('2022-03-27 07:54:31.12'); ---- 2022-03-27 07:54:31.120000 + +query T +SELECT DATE_ADD('week', 1, TODAY())=DATE_ADD('day', 7, TODAY()) +---- +1