#pragma once #include #include namespace DB { template static auto getKeyHolder(const IColumn & column, size_t row_num, Arena & arena) { if constexpr (is_plain_column) { return ArenaKeyHolder{column.getDataAt(row_num), arena}; } else { const char * begin = nullptr; StringRef serialized = column.serializeValueIntoArena(row_num, arena, begin); assert(serialized.data != nullptr); return SerializedKeyHolder{serialized, arena}; } } template static void deserializeAndInsert(StringRef str, IColumn & data_to) { if constexpr (is_plain_column) data_to.insertData(str.data, str.size); else data_to.deserializeAndInsertFromArena(str.data); } }