From 95f42b309548156824f14b5d3b1bba549df40654 Mon Sep 17 00:00:00 2001 From: Sri Krishna chowdary K Date: Tue, 7 Jan 2025 20:37:35 +0530 Subject: [PATCH] avoid converting table filter type OPTIONAL_FILTER to substrait Also, make sure filter type constant comparison always returns a boolean --- src/to_substrait.cpp | 4 +++- 1 file changed, 3 insertions(+), 1 deletion(-) diff --git a/src/to_substrait.cpp b/src/to_substrait.cpp index 6ff0b0a..b25a7db 100644 --- a/src/to_substrait.cpp +++ b/src/to_substrait.cpp @@ -698,7 +698,7 @@ substrait::Expression *DuckDBToSubstrait::TransformConstantComparisonFilter(uint auto s_expr = new substrait::Expression(); auto s_scalar = s_expr->mutable_scalar_function(); auto &constant_filter = dfilter.Cast(); - *s_scalar->mutable_output_type() = DuckToSubstraitType(return_type); + *s_scalar->mutable_output_type() = DuckToSubstraitType(LogicalTypeId::BOOLEAN); auto s_arg = s_scalar->add_arguments(); CreateFieldRef(s_arg->mutable_value(), col_idx); s_arg = s_scalar->add_arguments(); @@ -740,6 +740,8 @@ substrait::Expression *DuckDBToSubstrait::TransformFilter(uint64_t col_idx, Logi return TransformConjuctionAndFilter(col_idx, column_type, dfilter, return_type); case TableFilterType::CONSTANT_COMPARISON: return TransformConstantComparisonFilter(col_idx, column_type, dfilter, return_type); + case TableFilterType::OPTIONAL_FILTER: + return nullptr; default: throw InternalException("Unsupported table filter type"); }