#pragma once #include #include #include #include #include #include #include #include #include #include namespace DB { /** Проверить, существует ли таблица. Вернуть одну строку с одним столбцом result типа UInt8 со значением 0 или 1. */ class InterpreterExistsQuery : public IInterpreter { public: InterpreterExistsQuery(ASTPtr query_ptr_, Context & context_) : query_ptr(query_ptr_), context(context_) {} BlockIO execute() override { BlockIO res; res.in = executeImpl(); res.in_sample = getSampleBlock(); return res; } private: ASTPtr query_ptr; Context context; Block getSampleBlock() { ColumnWithNameAndType col; col.name = "result"; col.type = new DataTypeUInt8; col.column = col.type->createColumn(); Block block; block.insert(col); return block; } BlockInputStreamPtr executeImpl() { const ASTExistsQuery & ast = typeid_cast(*query_ptr); bool res = context.isTableExist(ast.database, ast.table); ColumnWithNameAndType col; col.name = "result"; col.type = new DataTypeUInt8; col.column = new ColumnConstUInt8(1, res); Block block; block.insert(col); return new OneBlockInputStream(block); } }; }