From 85f27f8d3f07dc168975971018f6358dd01397f2 Mon Sep 17 00:00:00 2001 From: robot-clickhouse Date: Sat, 7 Oct 2023 13:05:46 +0000 Subject: [PATCH] Backport #54844 to 23.7: Fix "Invalid number of rows in Chunk" in MaterializedPostgreSQL --- .../MaterializedPostgreSQLConsumer.cpp | 18 ++++++++++++++++++ 1 file changed, 18 insertions(+) diff --git a/src/Storages/PostgreSQL/MaterializedPostgreSQLConsumer.cpp b/src/Storages/PostgreSQL/MaterializedPostgreSQLConsumer.cpp index d01746ddf1be..6024a6b4f8fb 100644 --- a/src/Storages/PostgreSQL/MaterializedPostgreSQLConsumer.cpp +++ b/src/Storages/PostgreSQL/MaterializedPostgreSQLConsumer.cpp @@ -269,6 +269,20 @@ void MaterializedPostgreSQLConsumer::readTupleData( insertDefaultValue(buffer, column_idx); break; } + case 'b': /// Binary data. + { + LOG_WARNING(log, "We do not yet process this format of data, will insert default value"); + insertDefaultValue(buffer, column_idx); + break; + } + default: + { + LOG_WARNING(log, "Unexpected identifier: {}. This is a bug! Please report an issue on github", identifier); + chassert(false); + + insertDefaultValue(buffer, column_idx); + break; + } } }; @@ -281,6 +295,10 @@ void MaterializedPostgreSQLConsumer::readTupleData( } catch (...) { + LOG_ERROR(log, + "Got error while receiving value for column {}, will insert default value. Error: {}", + column_idx, getCurrentExceptionMessage(true)); + insertDefaultValue(buffer, column_idx); /// Let's collect only the first exception. /// This delaying of error throw is needed because