ClickHouse/src/Storages/StorageSnapshot.h

61 lines
1.7 KiB
C++
Raw Normal View History

#pragma once
#include <Storages/StorageInMemoryMetadata.h>
namespace DB
{
class IStorage;
class IMergeTreeDataPart;
using DataPartPtr = std::shared_ptr<const IMergeTreeDataPart>;
using DataPartsVector = std::vector<DataPartPtr>;
struct StorageSnapshot
{
using NameToTypeMap = std::unordered_map<String, DataTypePtr>;
const IStorage & storage;
const StorageMetadataPtr metadata;
const NameToTypeMap object_types;
const DataPartsVector parts;
StorageSnapshot(
const IStorage & storage_,
const StorageMetadataPtr & metadata_)
: storage(storage_), metadata(metadata_)
{
}
StorageSnapshot(
const IStorage & storage_,
const StorageMetadataPtr & metadata_,
const NameToTypeMap & object_types_)
: storage(storage_), metadata(metadata_), object_types(object_types_)
{
}
StorageSnapshot(
const IStorage & storage_,
const StorageMetadataPtr & metadata_,
const NameToTypeMap & object_types_,
const DataPartsVector & parts_)
: storage(storage_), metadata(metadata_), object_types(object_types_), parts(parts_)
{
}
NamesAndTypesList getColumns(const GetColumnsOptions & options) const;
/// Block with ordinary + materialized + aliases + virtuals + subcolumns.
Block getSampleBlockForColumns(const Names & column_names) const;
/// Verify that all the requested names are in the table and are set correctly:
/// list of names is not empty and the names do not repeat.
void check(const Names & column_names) const;
DataTypePtr getConcreteType(const String & column_name) const;
};
using StorageSnapshotPtr = std::shared_ptr<const StorageSnapshot>;
}