#include #include #include #include #include #include #include #include #include #include namespace DB { NamesAndTypesList AsynchronousInsertLogElement::getNamesAndTypes() { auto type_status = std::make_shared( DataTypeEnum8::Values { {"Ok", static_cast(Status::Ok)}, {"ParsingError", static_cast(Status::ParsingError)}, {"FlushError", static_cast(Status::FlushError)}, }); auto type_data_kind = std::make_shared( DataTypeEnum8::Values { {"Parsed", static_cast(DataKind::Parsed)}, {"Preprocessed", static_cast(DataKind::Preprocessed)}, }); return { {"event_date", std::make_shared()}, {"event_time", std::make_shared()}, {"event_time_microseconds", std::make_shared(6)}, {"query", std::make_shared()}, {"database", std::make_shared(std::make_shared())}, {"table", std::make_shared(std::make_shared())}, {"format", std::make_shared(std::make_shared())}, {"query_id", std::make_shared()}, {"bytes", std::make_shared()}, {"rows", std::make_shared()}, {"exception", std::make_shared()}, {"status", type_status}, {"data_kind", type_data_kind}, {"flush_time", std::make_shared()}, {"flush_time_microseconds", std::make_shared(6)}, {"flush_query_id", std::make_shared()}, }; } void AsynchronousInsertLogElement::appendToBlock(MutableColumns & columns) const { size_t i = 0; auto event_date = DateLUT::instance().toDayNum(event_time).toUnderType(); columns[i++]->insert(event_date); columns[i++]->insert(event_time); columns[i++]->insert(event_time_microseconds); columns[i++]->insert(query_for_logging); columns[i++]->insert(database); columns[i++]->insert(table); columns[i++]->insert(format); columns[i++]->insert(query_id); columns[i++]->insert(bytes); columns[i++]->insert(rows); columns[i++]->insert(exception); columns[i++]->insert(status); columns[i++]->insert(data_kind); columns[i++]->insert(flush_time); columns[i++]->insert(flush_time_microseconds); columns[i++]->insert(flush_query_id); } }