Analyzer join_use_nulls fix

This commit is contained in:
Maksim Kita 2023-02-05 14:30:04 +01:00
parent 0cba5848ac
commit 9b7cd64093

View File

@ -2960,14 +2960,21 @@ QueryTreeNodePtr QueryAnalyzer::tryResolveIdentifierFromJoin(const IdentifierLoo
bool join_use_nulls = scope.context->getSettingsRef().join_use_nulls; bool join_use_nulls = scope.context->getSettingsRef().join_use_nulls;
if (join_use_nulls if (join_use_nulls &&
&& (isFull(join_kind) || resolved_identifier->getNodeType() == QueryTreeNodeType::COLUMN &&
(isLeft(join_kind) && resolved_side && *resolved_side == JoinTableSide::Right) || (isFull(join_kind) ||
(isRight(join_kind) && resolved_side && *resolved_side == JoinTableSide::Left))) (isLeft(join_kind) && resolved_side && *resolved_side == JoinTableSide::Right) ||
(isRight(join_kind) && resolved_side && *resolved_side == JoinTableSide::Left)))
{ {
resolved_identifier = resolved_identifier->clone(); resolved_identifier = resolved_identifier->clone();
auto & resolved_column = resolved_identifier->as<ColumnNode &>(); auto & resolved_column = resolved_identifier->as<ColumnNode &>();
resolved_column.setColumnType(makeNullable(resolved_column.getColumnType())); const auto & resolved_column_type = resolved_column.getColumnType();
const auto & resolved_column_name = resolved_column.getColumnName();
auto to_nullable_function_resolver = FunctionFactory::instance().get("toNullable", scope.context);
auto to_nullable_function_arguments = {ColumnWithTypeAndName(nullptr, resolved_column_type, resolved_column_name)};
auto to_nullable_function = to_nullable_function_resolver->build(to_nullable_function_arguments);
resolved_column.setColumnType(to_nullable_function->getResultType());
} }
return resolved_identifier; return resolved_identifier;