#pragma once #include #include namespace DB { /** Столбец, содержащий лямбда-выражение. * Ведёт себя как столбец-константа. Содержит выражение, но не входные или выходные данные. */ class ColumnExpression : public IColumnDummy { public: ColumnExpression(size_t s_, ExpressionActionsPtr expression_, const NamesAndTypes & arguments_, DataTypePtr return_type_, std::string return_name_) : IColumnDummy(s_), expression(expression_), arguments(arguments_), return_type(return_type_), return_name(return_name_) {} std::string getName() const { return "ColumnExpression"; } ColumnPtr cloneDummy(size_t s_) const { return new ColumnExpression(s_, expression, arguments, return_type, return_name); } const ExpressionActionsPtr & getExpression() const { return expression; } const NamesAndTypes & getArguments() const { return arguments; } const DataTypePtr & getReturnType() const { return return_type; } const std::string & getReturnName() const { return return_name; } private: ExpressionActionsPtr expression; NamesAndTypes arguments; DataTypePtr return_type; std::string return_name; }; }