ClickHouse/dbms/src/Storages/ColumnsDescription.h

78 lines
2.2 KiB
C++
Raw Normal View History

#pragma once
#include <Core/NamesAndTypes.h>
#include <Core/Names.h>
#include <Storages/ColumnDefault.h>
#include <Core/Block.h>
2018-10-11 02:57:48 +00:00
#include <Storages/ColumnCodec.h>
namespace DB
{
/// key-values column_name, column_comment. column_comment should be non empty.
2018-11-12 15:45:35 +00:00
using ColumnComments = std::unordered_map<std::string, String>;
struct ColumnsDescription
{
NamesAndTypesList ordinary;
NamesAndTypesList materialized;
NamesAndTypesList aliases;
ColumnDefaults defaults;
ColumnComments comments;
2018-12-20 17:37:02 +00:00
ColumnCodecs codecs;
ColumnsDescription() = default;
ColumnsDescription(
NamesAndTypesList ordinary_,
NamesAndTypesList materialized_,
NamesAndTypesList aliases_,
2018-11-12 15:45:35 +00:00
ColumnDefaults defaults_,
2018-12-20 17:37:02 +00:00
ColumnComments comments_,
ColumnCodecs codecs_)
: ordinary(std::move(ordinary_))
, materialized(std::move(materialized_))
, aliases(std::move(aliases_))
, defaults(std::move(defaults_))
, comments(std::move(comments_))
2018-12-20 17:37:02 +00:00
, codecs(std::move(codecs_))
{}
explicit ColumnsDescription(NamesAndTypesList ordinary_) : ordinary(std::move(ordinary_)) {}
bool operator==(const ColumnsDescription & other) const
{
return ordinary == other.ordinary
&& materialized == other.materialized
&& aliases == other.aliases
&& defaults == other.defaults
2018-12-20 17:37:02 +00:00
&& comments == other.comments
&& codecs == other.codecs;
}
bool operator!=(const ColumnsDescription & other) const { return !(*this == other); }
/// ordinary + materialized.
2018-03-13 15:00:28 +00:00
NamesAndTypesList getAllPhysical() const;
/// ordinary + materialized + aliases.
NamesAndTypesList getAll() const;
2018-03-13 15:00:28 +00:00
Names getNamesOfPhysical() const;
2018-03-13 15:00:28 +00:00
NameAndTypePair getPhysical(const String & column_name) const;
2018-03-13 15:00:28 +00:00
bool hasPhysical(const String & column_name) const;
String toString() const;
2018-12-21 12:17:30 +00:00
CompressionCodecPtr getCodecOrDefault(const String & column_name, CompressionCodecPtr default_codec) const;
2018-10-11 02:57:48 +00:00
static ColumnsDescription parse(const String & str);
2018-10-11 02:57:48 +00:00
static const ColumnsDescription * loadFromContext(const Context & context, const String & db, const String & table);
};
}