From bc4b6b1f908d927eee1207889c74e8cbca11081b Mon Sep 17 00:00:00 2001 From: Sam Ansmink Date: Wed, 11 Sep 2024 12:45:14 +0200 Subject: [PATCH] handle when kernel returns a nullptr for the stats --- src/functions/delta_scan.cpp | 16 +++++++++++++--- 1 file changed, 13 insertions(+), 3 deletions(-) diff --git a/src/functions/delta_scan.cpp b/src/functions/delta_scan.cpp index 508c01c..728aca7 100644 --- a/src/functions/delta_scan.cpp +++ b/src/functions/delta_scan.cpp @@ -63,7 +63,9 @@ static void visit_callback(ffi::NullableCvoid engine_context, struct ffi::Kernel // Initialize the file metadata context->metadata.back()->delta_snapshot_version = context->version; context->metadata.back()->file_number = context->resolved_files.size() - 1; - context->metadata.back()->cardinality = stats->num_records; + if (stats) { + context->metadata.back()->cardinality = stats->num_records; + } // Fetch the deletion vector auto selection_vector_res = ffi::selection_vector_from_dv(dv_info, context->extern_engine.get(), context->global_state.get()); @@ -510,11 +512,19 @@ unique_ptr DeltaSnapshot::GetCardinality(ClientContext &context) } idx_t total_tuple_count = 0; + bool have_any_stats = false; for (auto &metadatum : metadata) { - total_tuple_count += metadatum->cardinality; + if (metadatum->cardinality != DConstants::INVALID_INDEX) { + have_any_stats = true; + total_tuple_count += metadatum->cardinality; + } + } + + if (have_any_stats) { + return make_uniq(total_tuple_count,total_tuple_count); } - return make_uniq(total_tuple_count,total_tuple_count); + return nullptr; } unique_ptr DeltaMultiFileReader::CreateInstance() {