ClickHouse/src/DataTypes/FieldToDataType.h

45 lines
1.6 KiB
C++
Raw Normal View History

2011-08-12 18:27:39 +00:00
#pragma once
2021-05-03 22:46:51 +00:00
#include <memory>
#include <Core/Types.h>
#include <Core/Field.h>
#include <Common/FieldVisitors.h>
2011-08-12 18:27:39 +00:00
namespace DB
{
class IDataType;
using DataTypePtr = std::shared_ptr<const IDataType>;
2018-02-28 04:30:27 +00:00
/** For a given Field returns the minimum data type that allows this value to be stored.
* Note that you still have to convert Field to corresponding data type before inserting to columns
* (for example, this is necessary to convert elements of Array to common type).
*/
class FieldToDataType : public StaticVisitor<DataTypePtr>
2011-08-12 18:27:39 +00:00
{
public:
2018-02-28 04:30:27 +00:00
DataTypePtr operator() (const Null & x) const;
DataTypePtr operator() (const UInt64 & x) const;
DataTypePtr operator() (const UInt128 & x) const;
2021-05-03 16:12:28 +00:00
DataTypePtr operator() (const UInt256 & x) const;
2018-02-28 04:30:27 +00:00
DataTypePtr operator() (const Int64 & x) const;
DataTypePtr operator() (const Int128 & x) const;
2021-05-03 16:12:28 +00:00
DataTypePtr operator() (const Int256 & x) const;
2021-05-03 22:46:51 +00:00
DataTypePtr operator() (const UUID & x) const;
2018-02-28 04:30:27 +00:00
DataTypePtr operator() (const Float64 & x) const;
DataTypePtr operator() (const String & x) const;
DataTypePtr operator() (const Array & x) const;
2020-03-08 22:38:12 +00:00
DataTypePtr operator() (const Tuple & tuple) const;
2020-10-10 06:49:03 +00:00
DataTypePtr operator() (const Map & map) const;
2018-08-23 19:11:31 +00:00
DataTypePtr operator() (const DecimalField<Decimal32> & x) const;
DataTypePtr operator() (const DecimalField<Decimal64> & x) const;
DataTypePtr operator() (const DecimalField<Decimal128> & x) const;
DataTypePtr operator() (const DecimalField<Decimal256> & x) const;
2019-02-11 13:11:52 +00:00
DataTypePtr operator() (const AggregateFunctionStateData & x) const;
2011-08-12 18:27:39 +00:00
};
}