#include #include #include #include #include #include #include #include namespace DB { namespace ErrorCodes { extern const int NUMBER_OF_ARGUMENTS_DOESNT_MATCH; extern const int ILLEGAL_TYPE_OF_ARGUMENT; } /// Just changes time zone information for data type. The calculation is free. class FunctionToTimeZone : public IFunction { public: static constexpr auto name = "toTimeZone"; static FunctionPtr create(const Context &) { return std::make_shared(); } String getName() const override { return name; } size_t getNumberOfArguments() const override { return 2; } DataTypePtr getReturnTypeImpl(const ColumnsWithTypeAndName & arguments) const override { if (arguments.size() != 2) throw Exception("Number of arguments for function " + getName() + " doesn't match: passed " + toString(arguments.size()) + ", should be 2", ErrorCodes::NUMBER_OF_ARGUMENTS_DOESNT_MATCH); const auto which_type = WhichDataType(arguments[0].type); if (!which_type.isDateTime() && !which_type.isDateTime64()) throw Exception{"Illegal type " + arguments[0].type->getName() + " of argument of function " + getName() + ". Should be DateTime or DateTime64", ErrorCodes::ILLEGAL_TYPE_OF_ARGUMENT}; String time_zone_name = extractTimeZoneNameFromFunctionArguments(arguments, 1, 0); if (which_type.isDateTime()) return std::make_shared(time_zone_name); const auto * date_time64 = assert_cast(arguments[0].type.get()); return std::make_shared(date_time64->getScale(), time_zone_name); } void executeImpl(Block & block, const ColumnNumbers & arguments, size_t result, size_t /*input_rows_count*/) override { block.getByPosition(result).column = block.getByPosition(arguments[0]).column; } }; void registerFunctionToTimeZone(FunctionFactory & factory) { factory.registerFunction(); } }