Skip to content

Commit

Permalink
[BugFix] Fix duplicate entries in be_logs; Add reset_delvec in script…
Browse files Browse the repository at this point in the history
…; Add BE id in error message when query failed

Signed-off-by: Binglin Chang <[email protected]>
  • Loading branch information
decster committed Sep 23, 2024
1 parent 26ceaa6 commit 4756897
Show file tree
Hide file tree
Showing 19 changed files with 96 additions and 73 deletions.
9 changes: 5 additions & 4 deletions be/src/common/greplog.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -33,11 +33,11 @@ namespace starrocks {
static std::vector<string> list_log_files_in_dir(const string& log_dir, char level) {
std::vector<string> files;
// if level in WARNING, ERROR, FATAL, use logging logs, else use info logs
const std::string pattern = string("WEF").find(level) == string::npos ? "be.INFO.log." : "be.WARNING.log.";
const std::string pattern = string("WEF").find(level) == string::npos ? ".INFO.log." : ".WARNING.log.";
for (const auto& entry : filesystem::directory_iterator(log_dir)) {
if (entry.is_regular_file()) {
auto name = entry.path().filename().string();
if (name.length() > pattern.length() && name.substr(0, pattern.length()) == pattern) {
if (name.length() > pattern.length() && name.find(pattern) != string::npos) {
files.push_back(entry.path().string());
}
}
Expand Down Expand Up @@ -180,7 +180,7 @@ Status grep_log_single_file(const string& path, int64_t start_ts, int64_t end_ts
ctx.line_len = read;
if (database == nullptr) {
// no pattern, add all lines
scan_by_line_handler(0, 0, 0, 0, &ctx);
scan_by_line_handler(0, 0, read, 0, &ctx);
} else {
if (hs_scan(database, line, read, 0, scratch, scan_by_line_handler, &ctx) != HS_SUCCESS) {
break;
Expand All @@ -206,7 +206,8 @@ Status grep_log(int64_t start_ts, int64_t end_ts, char level, const std::string&
hs_database_t* database = nullptr;
if (!pattern.empty()) {
hs_compile_error_t* compile_err;
if (hs_compile(pattern.c_str(), 0, HS_MODE_BLOCK, nullptr, &database, &compile_err) != HS_SUCCESS) {
if (hs_compile(pattern.c_str(), HS_FLAG_SINGLEMATCH, HS_MODE_BLOCK, nullptr, &database, &compile_err) !=
HS_SUCCESS) {
hs_free_compile_error(compile_err);
return Status::InternalError(
strings::Substitute("grep log failed compile pattern $0 failed $1", pattern, compile_err->message));
Expand Down
4 changes: 4 additions & 0 deletions be/src/exec/pipeline/pipeline_driver_executor.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@

#include <memory>

#include "agent/master_info.h"
#include "exec/pipeline/stream_pipeline_driver.h"
#include "exec/workgroup/work_group.h"
#include "gutil/strings/substitute.h"
Expand Down Expand Up @@ -167,6 +168,9 @@ void GlobalDriverExecutor::_worker_thread() {
}

if (!status.ok()) {
auto o_id = get_backend_id();
int64_t be_id = o_id.has_value() ? o_id.value() : 0;
status = status.clone_and_append(fmt::format("BE:{}", be_id));
LOG(WARNING) << "[Driver] Process error, query_id=" << print_id(driver->query_ctx()->query_id())
<< ", instance_id=" << print_id(driver->fragment_ctx()->fragment_instance_id())
<< ", status=" << status;
Expand Down
2 changes: 1 addition & 1 deletion be/src/exec/schema_scanner/schema_be_logs_scanner.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -48,7 +48,7 @@ Status SchemaBeLogsScanner::start(RuntimeState* state) {
if (_param->log_end_ts > 0) {
end_ts = _param->log_end_ts;
}
string level;
string level = "I";
string pattern;
if (_param->log_level != nullptr) {
level = *_param->log_level;
Expand Down
12 changes: 12 additions & 0 deletions be/src/script/script.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -30,6 +30,7 @@
#include "io/io_profiler.h"
#include "runtime/exec_env.h"
#include "runtime/mem_tracker.h"
#include "storage/del_vector.h"
#include "storage/primary_key_dump.h"
#include "storage/storage_engine.h"
#include "storage/tablet.h"
Expand Down Expand Up @@ -355,6 +356,16 @@ class StorageEngineRef {
}
}

// this method is specifically used to recover "no delete vector found" error caused by corrupt pk tablet metadata
static std::string reset_delvec(int64_t tablet_id, int64_t segment_id, int64_t version) {
auto tablet = get_tablet(tablet_id);
RETURN_IF_UNLIKELY_NULL(tablet, "tablet not found");
DelVector dv;
dv.init(version, nullptr, 0);
auto st = TabletMetaManager::set_del_vector(tablet->data_dir()->get_meta(), tablet_id, segment_id, dv);
return st.to_string();
}

static size_t submit_manual_compaction_task_for_table(int64_t table_id, int64_t rowset_size_threshold) {
auto infos = get_tablet_infos(table_id, -1);
for (auto& info : infos) {
Expand Down Expand Up @@ -552,6 +563,7 @@ class StorageEngineRef {
REG_STATIC_METHOD(StorageEngineRef, get_tablet_info);
REG_STATIC_METHOD(StorageEngineRef, get_tablet_infos);
REG_STATIC_METHOD(StorageEngineRef, get_tablet_meta_json);
REG_STATIC_METHOD(StorageEngineRef, reset_delvec);
REG_STATIC_METHOD(StorageEngineRef, get_tablet);
REG_STATIC_METHOD(StorageEngineRef, drop_tablet);
REG_STATIC_METHOD(StorageEngineRef, get_data_dirs);
Expand Down
6 changes: 6 additions & 0 deletions be/test/storage/tablet_updates_test.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@

#include <random>

#include "script/script.h"
#include "storage/local_primary_key_recover.h"
#include "storage/primary_key_dump.h"
#include "util/failpoint/fail_point.h"
Expand Down Expand Up @@ -343,6 +344,11 @@ void TabletUpdatesTest::test_writeread(bool enable_persistent_index) {
auto rs0 = create_rowset(_tablet, keys);
ASSERT_TRUE(_tablet->rowset_commit(2, rs0).ok());
ASSERT_EQ(2, _tablet->updates()->max_version());

string o;
ASSERT_TRUE(execute_script(fmt::format("StorageEngine.reset_delvec({}, {}, 2)", _tablet->tablet_id(), 0), o).ok());
ASSERT_TRUE(execute_script("ExecEnv.grep_log_as_string(0,0,'I','tablet_manager',10)", o).ok());

auto rs1 = create_rowset(_tablet, keys);
ASSERT_TRUE(_tablet->rowset_commit(3, rs1).ok());
ASSERT_EQ(3, _tablet->updates()->max_version());
Expand Down
4 changes: 2 additions & 2 deletions test/sql/test_array_fn/R/test_array_fn
Original file line number Diff line number Diff line change
Expand Up @@ -4029,11 +4029,11 @@ None None
-- !result
select d_6, d_5, all_match(d_6,d_5, (x,y)->x >y) from array_test order by pk;
-- result:
E: (1064, "Input array element's size is not equal in array_map().")
[REGEX].*Input array element's size is not equal in array_map().*
-- !result
select d_6, d_5, any_match(d_6,d_5, (x,y)->x >y) from array_test order by pk;
-- result:
E: (1064, "Input array element's size is not equal in array_map().")
[REGEX].*Input array element's size is not equal in array_map().*
-- !result
select all_match((x,y) -> x < y, []);
-- result:
Expand Down
8 changes: 4 additions & 4 deletions test/sql/test_array_fn/R/test_array_sortby
Original file line number Diff line number Diff line change
Expand Up @@ -408,19 +408,19 @@ select array_sortby([1,2,3,4,5,6], ['a', 'b', 'c', 'c', 'b', 'a'], cast(['2023-1
-- !result
select array_sortby([1,2,null,4,5,6], ['a', 'b', 'c', 'c', 'b', 'a', 1], [11, 22, 32, 31, 21, 12]);
-- result:
E: (1064, "Input arrays' size are not equal in array_sortby.")
[REGEX].*Input arrays' size are not equal in array_sortby.*
-- !result
select array_sortby([1,2,null,4,5,6], ['a', 'b', 'c', 'c', 'b', 'a', 1], cast(null as array<int>), [11, 22, 32, 31, 21, 12]);
-- result:
E: (1064, "Input arrays' size are not equal in array_sortby.")
[REGEX].*Input arrays' size are not equal in array_sortby.*
-- !result
select array_sortby([1,2,3,4,5,6], ['a', 'b', null, null, 'b', 'a', 1], [11, 22, 32, 31, 21, 12]);
-- result:
E: (1064, "Input arrays' size are not equal in array_sortby.")
[REGEX].*Input arrays' size are not equal in array_sortby.*
-- !result
select array_sortby([1,2,3,4,5,6], ['a', 'b', null, null, 'b', 'a'], [11, 22, 32, 31, null, null, 1]);
-- result:
E: (1064, "Input arrays' size are not equal in array_sortby.")
[REGEX].*Input arrays' size are not equal in array_sortby.*
-- !result
-- name: test_array_sortby_3
with w1 as (select column_0 as source, column_1 as key1, column_2 as key2 from (values
Expand Down
30 changes: 15 additions & 15 deletions test/sql/test_decimal/R/test_decimal_overflow
Original file line number Diff line number Diff line change
Expand Up @@ -43,7 +43,7 @@ None
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ 274.97790000000000000000 * (round(1103.00000000000000000000 * 1.0000,16) /round(1103.00000000000000000000,16));
-- result:
E: (1064, "Expr evaluate meet error: The 'mul' operation involving decimal values overflows")
[REGEX].*Expr evaluate meet error: The 'mul' operation involving decimal values overflows.*
-- !result
select cast(c_d32 * c_d32 as decimal32) from t_decimal_overflow where c_id = 1;
-- result:
Expand Down Expand Up @@ -95,51 +95,51 @@ None
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d32 * c_d32 as decimal32) from t_decimal_overflow where c_id = 1;
-- result:
E: (1064, 'Expr evaluate meet error: The type cast from decimal to decimal overflows')
[REGEX].*Expr evaluate meet error: The type cast from decimal to decimal overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d32 * c_d32 as decimal32) from t_decimal_overflow where c_id = 2;
-- result:
E: (1064, 'Expr evaluate meet error: The type cast from decimal to decimal overflows')
[REGEX].*Expr evaluate meet error: The type cast from decimal to decimal overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d64 * c_d64 as decimal64) from t_decimal_overflow where c_id = 1;
-- result:
E: (1064, 'Expr evaluate meet error: The type cast from decimal to decimal overflows')
[REGEX].*Expr evaluate meet error: The type cast from decimal to decimal overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d64 * c_d64 as decimal64) from t_decimal_overflow where c_id = 2;
-- result:
E: (1064, 'Expr evaluate meet error: The type cast from decimal to decimal overflows')
[REGEX].*Expr evaluate meet error: The type cast from decimal to decimal overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d128 * c_d128 as decimal128) from t_decimal_overflow where c_id = 1;
-- result:
E: (1064, "Expr evaluate meet error: The 'mul' operation involving decimal values overflows")
[REGEX].*Expr evaluate meet error: The 'mul' operation involving decimal values overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d128 * c_d128 as decimal128) from t_decimal_overflow where c_id = 2;
-- result:
E: (1064, "Expr evaluate meet error: The 'mul' operation involving decimal values overflows")
[REGEX].*Expr evaluate meet error: The 'mul' operation involving decimal values overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d32 * 1.000 as decimal32) from t_decimal_overflow where c_id = 1;
-- result:
E: (1064, 'Expr evaluate meet error: The type cast from decimal to decimal overflows')
[REGEX].*Expr evaluate meet error: The type cast from decimal to decimal overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d32 * 1.000 as decimal32) from t_decimal_overflow where c_id = 2;
-- result:
E: (1064, 'Expr evaluate meet error: The type cast from decimal to decimal overflows')
[REGEX].*Expr evaluate meet error: The type cast from decimal to decimal overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d64 * 1.000000 as decimal64) from t_decimal_overflow where c_id = 1;
-- result:
E: (1064, 'Expr evaluate meet error: The type cast from decimal to decimal overflows')
[REGEX].*Expr evaluate meet error: The type cast from decimal to decimal overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d64 * 1.000000 as decimal64) from t_decimal_overflow where c_id = 2;
-- result:
E: (1064, 'Expr evaluate meet error: The type cast from decimal to decimal overflows')
[REGEX].*Expr evaluate meet error: The type cast from decimal to decimal overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d128 * 1.000000000 as decimal128) from t_decimal_overflow where c_id = 1;
-- result:
E: (1064, "Expr evaluate meet error: The 'mul' operation involving decimal values overflows")
[REGEX].*Expr evaluate meet error: The 'mul' operation involving decimal values overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ cast(c_d128 * 1.000000000 as decimal128) from t_decimal_overflow where c_id = 2;
-- result:
E: (1064, "Expr evaluate meet error: The 'mul' operation involving decimal values overflows")
[REGEX].*Expr evaluate meet error: The 'mul' operation involving decimal values overflows.*
-- !result
select c_id - 1.12345678901234567890 from t_decimal_overflow where c_id = 1;
-- result:
Expand All @@ -155,9 +155,9 @@ select avg(c0- 2.8665963056616452*(lt - 3.062472673706541)) as adjust_lt from (s
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ max(lt- 2.8665963056616452*(c2 - 3.062472673706541)) as adjust_lt from (select c0, array_sum(c1) lt, c2 from avg_test) t group by c0;
-- result:
E: (1064, "Expr evaluate meet error: The 'mul' operation involving decimal values overflows")
[REGEX].*Expr evaluate meet error: The 'mul' operation involving decimal values overflows.*
-- !result
select /*+ SET_VAR(sql_mode='ERROR_IF_OVERFLOW')*/ avg(lt- 2.8665963056616452*(c2 - 3.062472673706541)) as adjust_lt from (select c0, array_sum(c1) lt, c2 from avg_test) t group by c0;
-- result:
E: (1064, "Expr evaluate meet error: The 'mul' operation involving decimal values overflows")
[REGEX].*Expr evaluate meet error: The 'mul' operation involving decimal values overflows.*
-- !result
Original file line number Diff line number Diff line change
Expand Up @@ -126,7 +126,7 @@ INSERT INTO t VALUES (1, NULL);
-- !result
SELECT dict_mapping("dict", col_1, col_2) FROM t;
-- result:
E: (1064, 'invalid parameter : get NULL paramenter')
[REGEX].*invalid parameter : get NULL paramenter.*
-- !result
DROP DATABASE test_dictmapping_null_column;
-- result:
Expand Down Expand Up @@ -291,11 +291,11 @@ insert into t_dictmapping_null_if_not_found values (1,default);
-- !result
select dict_mapping("t_dictmapping_null_if_not_found", 2);
-- result:
E: (1064, 'query failed if record not exist in dict table.')
[REGEX].*query failed if record not exist in dict table.*
-- !result
select dict_mapping("t_dictmapping_null_if_not_found", 2, false);
-- result:
E: (1064, 'query failed if record not exist in dict table.')
[REGEX].*query failed if record not exist in dict table.*
-- !result
select dict_mapping("t_dictmapping_null_if_not_found", 2, true);
-- result:
Expand Down
18 changes: 9 additions & 9 deletions test/sql/test_dictionary/R/test_dictionary
Original file line number Diff line number Diff line change
Expand Up @@ -84,7 +84,7 @@ SELECT dictionary_get("test_dictionary_basic_operation", 1);
-- !result
SELECT dictionary_get("test_dictionary_basic_operation", 2);
-- result:
E: (1064, 'key not found in dictionary cache')
[REGEX].*key not found in dictionary cache.*
-- !result
DROP DICTIONARY test_dictionary_basic_operation CACHE;
-- result:
Expand Down Expand Up @@ -1353,11 +1353,11 @@ INSERT INTO t_dictionary_null_if_not_exist VALUES (2,2),(4,4);
-- !result
SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k) FROM t_dictionary_null_if_not_exist ORDER BY k;
-- result:
E: (1064, 'key not found in dictionary cache')
[REGEX].*key not found in dictionary cache.*
-- !result
SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k, false) FROM t_dictionary_null_if_not_exist ORDER BY k;
-- result:
E: (1064, 'key not found in dictionary cache')
[REGEX].*key not found in dictionary cache.*
-- !result
SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k, true) FROM t_dictionary_null_if_not_exist ORDER BY k;
-- result:
Expand All @@ -1377,7 +1377,7 @@ SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k, tRuE) FROM t_di
-- !result
SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k, FaLsE) FROM t_dictionary_null_if_not_exist ORDER BY k;
-- result:
E: (1064, 'key not found in dictionary cache')
[REGEX].*key not found in dictionary cache.*
-- !result
SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k, xxxx) FROM t_dictionary_null_if_not_exist ORDER BY k;
-- result:
Expand Down Expand Up @@ -1423,7 +1423,7 @@ PROPERTIES (
-- !result
INSERT INTO t_dictionary_null_if_not_exist_gen_column VALUES (1),(2),(3),(4),(5);
-- result:
E: (5025, 'key not found in dictionary cache')
[REGEX].*key not found in dictionary cache.*
-- !result
SELECT * FROM t_dictionary_null_if_not_exist_gen_column;
-- result:
Expand Down Expand Up @@ -1478,11 +1478,11 @@ INSERT INTO t_dictionary_null_if_not_exist VALUES (2,2),(4,4);
-- !result
SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k) FROM t_dictionary_null_if_not_exist ORDER BY k;
-- result:
E: (1064, 'key not found in dictionary cache')
[REGEX].*key not found in dictionary cache.*
-- !result
SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k, false) FROM t_dictionary_null_if_not_exist ORDER BY k;
-- result:
E: (1064, 'key not found in dictionary cache')
[REGEX].*key not found in dictionary cache.*
-- !result
SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k, true) FROM t_dictionary_null_if_not_exist ORDER BY k;
-- result:
Expand All @@ -1502,7 +1502,7 @@ SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k, tRuE) FROM t_di
-- !result
SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k, FaLsE) FROM t_dictionary_null_if_not_exist ORDER BY k;
-- result:
E: (1064, 'key not found in dictionary cache')
[REGEX].*key not found in dictionary cache.*
-- !result
SELECT k, dictionary_get("test_dictionary_null_if_not_exist", k, xxxx) FROM t_dictionary_null_if_not_exist ORDER BY k;
-- result:
Expand Down Expand Up @@ -1552,7 +1552,7 @@ PROPERTIES (
-- !result
INSERT INTO t_dictionary_null_if_not_exist_gen_column VALUES (1),(2),(3),(4),(5);
-- result:
E: (5025, 'key not found in dictionary cache')
[REGEX].*key not found in dictionary cache.*
-- !result
SELECT * FROM t_dictionary_null_if_not_exist_gen_column;
-- result:
Expand Down
2 changes: 1 addition & 1 deletion test/sql/test_external_file/R/test_orc_predicates
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ set sql_dialect='trino';
-- !result
select count(*) from split_orc_error where split(col1, 'a')[2]='x';
-- result:
E: (1064, 'Array subscript must be less than or equal to array length: 2 > 1')
[REGEX].*Array subscript must be less than or equal to array length: 2 > 1.*
-- !result
drop table split_orc_error;
-- result:
Expand Down
20 changes: 10 additions & 10 deletions test/sql/test_function/R/test_time_slice
Original file line number Diff line number Diff line change
Expand Up @@ -68,23 +68,23 @@ select time_slice('2023-12-31 03:12:04',interval 2147483647 second);
-- !result
select time_slice('0000-01-01',interval 5 year);
-- result:
E: (1064, "time used with time_slice can't before 0001-01-01 00:00:00")
[REGEX].*time used with time_slice can't before 0001-01-01 00:00:00.*
-- !result
select time_slice('0000-01-01',interval 5 month);
-- result:
E: (1064, "time used with time_slice can't before 0001-01-01 00:00:00")
[REGEX].*time used with time_slice can't before 0001-01-01 00:00:00.*
-- !result
select time_slice('0000-01-01',interval 5 day);
-- result:
E: (1064, "time used with time_slice can't before 0001-01-01 00:00:00")
[REGEX].*time used with time_slice can't before 0001-01-01 00:00:00.*
-- !result
select time_slice('0000-01-01',interval 5 quarter);
-- result:
E: (1064, "time used with time_slice can't before 0001-01-01 00:00:00")
[REGEX].*time used with time_slice can't before 0001-01-01 00:00:00.*
-- !result
select time_slice('0000-01-01',interval 5 week);
-- result:
E: (1064, "time used with time_slice can't before 0001-01-01 00:00:00")
[REGEX].*time used with time_slice can't before 0001-01-01 00:00:00.*
-- !result
select time_slice('9999-12-31',interval 5 year, ceil);
-- result:
Expand Down Expand Up @@ -219,23 +219,23 @@ select time_slice('2023-12-31 03:12:04',interval 2147483647 second);
-- !result
select time_slice('0000-01-01',interval 5 year);
-- result:
E: (1064, "time used with time_slice can't before 0001-01-01 00:00:00")
[REGEX].*time used with time_slice can't before 0001-01-01 00:00:00.*
-- !result
select time_slice('0000-01-01',interval 5 month);
-- result:
E: (1064, "time used with time_slice can't before 0001-01-01 00:00:00")
[REGEX].*time used with time_slice can't before 0001-01-01 00:00:00.*
-- !result
select time_slice('0000-01-01',interval 5 day);
-- result:
E: (1064, "time used with time_slice can't before 0001-01-01 00:00:00")
[REGEX].*time used with time_slice can't before 0001-01-01 00:00:00.*
-- !result
select time_slice('0000-01-01',interval 5 quarter);
-- result:
E: (1064, "time used with time_slice can't before 0001-01-01 00:00:00")
[REGEX].*time used with time_slice can't before 0001-01-01 00:00:00.*
-- !result
select time_slice('0000-01-01',interval 5 week);
-- result:
E: (1064, "time used with time_slice can't before 0001-01-01 00:00:00")
[REGEX].*time used with time_slice can't before 0001-01-01 00:00:00.*
-- !result
select time_slice('9999-12-31',interval 5 year, ceil);
-- result:
Expand Down
Loading

0 comments on commit 4756897

Please sign in to comment.