2012-08-23 18:43:57 +00:00
|
|
|
#pragma once
|
|
|
|
|
2017-04-01 09:19:00 +00:00
|
|
|
#include <DataTypes/IDataType.h>
|
2012-08-23 18:43:57 +00:00
|
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
{
|
|
|
|
|
2017-04-17 11:56:55 +00:00
|
|
|
/** Tuple data type.
|
|
|
|
* Used as an intermediate result when evaluating expressions.
|
|
|
|
* Also can be used as a column - the result of the query execution.
|
|
|
|
* Can not be saved to tables.
|
2012-08-23 18:43:57 +00:00
|
|
|
*/
|
2015-06-09 18:58:18 +00:00
|
|
|
class DataTypeTuple final : public IDataType
|
2012-08-23 18:43:57 +00:00
|
|
|
{
|
|
|
|
private:
|
2017-04-01 07:20:54 +00:00
|
|
|
DataTypes elems;
|
2012-08-23 18:43:57 +00:00
|
|
|
public:
|
2017-04-01 07:20:54 +00:00
|
|
|
DataTypeTuple(DataTypes elems_) : elems(elems_) {}
|
|
|
|
|
|
|
|
std::string getName() const override;
|
2017-07-16 03:05:40 +00:00
|
|
|
const char * getFamilyName() const override { return "Tuple"; }
|
2017-04-01 07:20:54 +00:00
|
|
|
DataTypePtr clone() const override { return std::make_shared<DataTypeTuple>(elems); }
|
|
|
|
|
2017-07-16 03:05:40 +00:00
|
|
|
bool canBeInsideNullable() const override { return false; }
|
|
|
|
|
2017-04-01 07:20:54 +00:00
|
|
|
void serializeBinary(const Field & field, WriteBuffer & ostr) const override;
|
|
|
|
void deserializeBinary(Field & field, ReadBuffer & istr) const override;
|
|
|
|
void serializeBinary(const IColumn & column, size_t row_num, WriteBuffer & ostr) const override;
|
|
|
|
void deserializeBinary(IColumn & column, ReadBuffer & istr) const override;
|
|
|
|
void serializeText(const IColumn & column, size_t row_num, WriteBuffer & ostr) const override;
|
|
|
|
void deserializeText(IColumn & column, ReadBuffer & istr) const;
|
|
|
|
void serializeTextEscaped(const IColumn & column, size_t row_num, WriteBuffer & ostr) const override;
|
|
|
|
void deserializeTextEscaped(IColumn & column, ReadBuffer & istr) const override;
|
|
|
|
void serializeTextQuoted(const IColumn & column, size_t row_num, WriteBuffer & ostr) const override;
|
|
|
|
void deserializeTextQuoted(IColumn & column, ReadBuffer & istr) const override;
|
2017-07-04 16:26:38 +00:00
|
|
|
void serializeTextJSON(const IColumn & column, size_t row_num, WriteBuffer & ostr, const FormatSettingsJSON & settings) const override;
|
2017-04-01 07:20:54 +00:00
|
|
|
void deserializeTextJSON(IColumn & column, ReadBuffer & istr) const override;
|
|
|
|
void serializeTextXML(const IColumn & column, size_t row_num, WriteBuffer & ostr) const override;
|
|
|
|
|
2017-04-17 11:56:55 +00:00
|
|
|
/// Tuples in CSV format will be serialized as separate columns (that is, losing their nesting in the tuple).
|
2017-04-01 07:20:54 +00:00
|
|
|
void serializeTextCSV(const IColumn & column, size_t row_num, WriteBuffer & ostr) const override;
|
|
|
|
void deserializeTextCSV(IColumn & column, ReadBuffer & istr, const char delimiter) const override;
|
|
|
|
|
|
|
|
void serializeBinaryBulk(const IColumn & column, WriteBuffer & ostr, size_t offset, size_t limit) const override;
|
|
|
|
|
2017-04-17 11:56:55 +00:00
|
|
|
/** `limit` must be exactly equal to the number of serialized values.
|
|
|
|
* It is because of this (the inability to read a smaller piece of recorded data) that Tuple can not be used to store data in tables.
|
|
|
|
* (Although they can be used to transfer data over a network in Native format.)
|
2017-04-01 07:20:54 +00:00
|
|
|
*/
|
|
|
|
void deserializeBinaryBulk(IColumn & column, ReadBuffer & istr, size_t limit, double avg_value_size_hint) const override;
|
|
|
|
|
|
|
|
ColumnPtr createColumn() const override;
|
|
|
|
|
|
|
|
Field getDefault() const override;
|
2017-09-01 21:37:57 +00:00
|
|
|
void insertDefaultInto(IColumn & column) const override;
|
|
|
|
|
2017-04-01 07:20:54 +00:00
|
|
|
const DataTypes & getElements() const { return elems; }
|
2012-08-23 18:43:57 +00:00
|
|
|
};
|
|
|
|
|
|
|
|
}
|
|
|
|
|