ClickHouse/src/Storages/VirtualColumnsDescription.cpp

Ignoring revisions in .git-blame-ignore-revs. Click here to bypass and see the normal blame view.

95 lines
3.0 KiB
C++
Raw Normal View History

2024-02-21 00:57:35 +00:00
#include <Storages/VirtualColumnsDescription.h>
namespace DB
{
namespace ErrorCodes
{
extern const int DUPLICATE_COLUMN;
extern const int NO_SUCH_COLUMN_IN_TABLE;
}
VirtualColumnDescription::VirtualColumnDescription(
String name_, DataTypePtr type_, ASTPtr codec_, String comment_, VirtualsKind kind_)
: ColumnDescription(std::move(name_), std::move(type_), std::move(codec_), std::move(comment_))
, kind(kind_)
{
}
2024-02-29 18:01:54 +00:00
void VirtualColumnsDescription::add(VirtualColumnDescription desc)
2024-02-21 00:57:35 +00:00
{
2024-02-29 18:01:54 +00:00
if (container.get<1>().contains(desc.name))
throw Exception(ErrorCodes::DUPLICATE_COLUMN, "Virtual column {} already exists", desc.name);
container.get<0>().push_back(std::move(desc));
2024-02-21 00:57:35 +00:00
}
void VirtualColumnsDescription::addEphemeral(String name, DataTypePtr type, String comment)
{
add({std::move(name), std::move(type), nullptr, std::move(comment), VirtualsKind::Ephemeral});
}
void VirtualColumnsDescription::addPersistent(String name, DataTypePtr type, ASTPtr codec, String comment)
{
add({std::move(name), std::move(type), std::move(codec), std::move(comment), VirtualsKind::Persistent});
}
NamesAndTypesList VirtualColumnsDescription::get(VirtualsKind kind) const
{
NamesAndTypesList result;
for (const auto & column : container)
if (static_cast<UInt8>(column.kind) & static_cast<UInt8>(kind))
result.emplace_back(column.name, column.type);
return result;
}
std::optional<NameAndTypePair> VirtualColumnsDescription::tryGet(const String & name, VirtualsKind kind) const
{
2024-02-29 18:01:54 +00:00
auto it = container.get<1>().find(name);
if (it != container.get<1>().end() && (static_cast<UInt8>(it->kind) & static_cast<UInt8>(kind)))
2024-02-21 00:57:35 +00:00
return NameAndTypePair{it->name, it->type};
return {};
}
NameAndTypePair VirtualColumnsDescription::get(const String & name, VirtualsKind kind) const
{
auto column = tryGet(name, kind);
if (!column)
throw Exception(ErrorCodes::NO_SUCH_COLUMN_IN_TABLE, "There is no virtual column {}", name);
return *column;
}
std::optional<VirtualColumnDescription> VirtualColumnsDescription::tryGetDescription(const String & name, VirtualsKind kind) const
{
2024-02-29 18:01:54 +00:00
auto it = container.get<1>().find(name);
if (it != container.get<1>().end() && (static_cast<UInt8>(it->kind) & static_cast<UInt8>(kind)))
2024-02-21 00:57:35 +00:00
return *it;
return {};
}
VirtualColumnDescription VirtualColumnsDescription::getDescription(const String & name, VirtualsKind kind) const
{
auto column = tryGetDescription(name, kind);
if (!column)
throw Exception(ErrorCodes::NO_SUCH_COLUMN_IN_TABLE, "There is no virtual column {}", name);
return *column;
}
NamesAndTypesList VirtualColumnsDescription::getNamesAndTypesList() const
{
NamesAndTypesList result;
for (const auto & desc : container)
result.emplace_back(desc.name, desc.type);
return result;
}
Block VirtualColumnsDescription::getSampleBlock() const
{
Block result;
for (const auto & desc : container)
result.insert({desc.type->createColumn(), desc.type, desc.name});
return result;
}
}