ClickHouse/dbms/src/Storages/ColumnsDescription.h

71 lines
1.9 KiB
C++
Raw Normal View History

#pragma once
#include <Core/NamesAndTypes.h>
#include <Core/Names.h>
#include <Storages/ColumnDefault.h>
#include <Core/Block.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;
ColumnsDescription() = default;
ColumnsDescription(
NamesAndTypesList ordinary_,
NamesAndTypesList materialized_,
NamesAndTypesList aliases_,
2018-11-12 15:45:35 +00:00
ColumnDefaults defaults_,
ColumnComments comments_)
: ordinary(std::move(ordinary_))
, materialized(std::move(materialized_))
, aliases(std::move(aliases_))
, defaults(std::move(defaults_))
, comments(std::move(comments_))
{}
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
&& comments == other.comments;
}
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;
static ColumnsDescription parse(const String & str);
static const ColumnsDescription * loadFromContext(const Context & context, const String & db, const String & table);
};
}