2014-03-09 17:36:01 +00:00
|
|
|
|
#pragma once
|
|
|
|
|
|
|
|
|
|
#include <DB/Core/Names.h>
|
|
|
|
|
#include <DB/Core/NamesAndTypes.h>
|
|
|
|
|
#include <DB/Core/Exception.h>
|
|
|
|
|
#include <DB/Core/Block.h>
|
|
|
|
|
|
|
|
|
|
namespace DB
|
|
|
|
|
{
|
|
|
|
|
|
|
|
|
|
class Context;
|
|
|
|
|
|
2014-03-19 10:45:13 +00:00
|
|
|
|
/** Описание таблицы.
|
|
|
|
|
* Не thread safe. См. IStorage::lockStructure().
|
2014-03-09 17:36:01 +00:00
|
|
|
|
*/
|
2014-03-19 10:45:13 +00:00
|
|
|
|
class ITableDeclaration
|
2014-03-09 17:36:01 +00:00
|
|
|
|
{
|
|
|
|
|
public:
|
2014-03-19 10:45:13 +00:00
|
|
|
|
/** Имя таблицы.
|
|
|
|
|
*/
|
2014-05-12 00:45:50 +00:00
|
|
|
|
virtual std::string getTableName() const = 0;
|
2014-03-09 17:36:01 +00:00
|
|
|
|
|
|
|
|
|
/** Получить список имён и типов столбцов таблицы, только невиртуальные.
|
|
|
|
|
*/
|
|
|
|
|
virtual const NamesAndTypesList & getColumnsList() const = 0;
|
|
|
|
|
|
2014-03-13 15:00:06 +00:00
|
|
|
|
/** Получить список имён столбцов таблицы, только невиртуальные.
|
|
|
|
|
*/
|
|
|
|
|
virtual Names getColumnNamesList() const;
|
|
|
|
|
|
2014-03-09 17:36:01 +00:00
|
|
|
|
/** Получить описание реального (невиртуального) столбца по его имени.
|
|
|
|
|
*/
|
|
|
|
|
virtual NameAndTypePair getRealColumn(const String & column_name) const;
|
|
|
|
|
|
|
|
|
|
/** Присутствует ли реальный (невиртуальный) столбец с таким именем.
|
|
|
|
|
*/
|
|
|
|
|
virtual bool hasRealColumn(const String & column_name) const;
|
|
|
|
|
|
|
|
|
|
/** Получить описание любого столбца по его имени.
|
|
|
|
|
*/
|
|
|
|
|
virtual NameAndTypePair getColumn(const String & column_name) const;
|
|
|
|
|
|
|
|
|
|
/** Присутствует ли столбец с таким именем.
|
|
|
|
|
*/
|
|
|
|
|
virtual bool hasColumn(const String & column_name) const;
|
|
|
|
|
|
|
|
|
|
const DataTypePtr getDataTypeByName(const String & column_name) const;
|
|
|
|
|
|
|
|
|
|
/** То же самое, но в виде блока-образца.
|
|
|
|
|
*/
|
|
|
|
|
Block getSampleBlock() const;
|
|
|
|
|
|
|
|
|
|
/** Проверить, что все запрошенные имена есть в таблице и заданы корректно.
|
|
|
|
|
* (список имён не пустой и имена не повторяются)
|
|
|
|
|
*/
|
|
|
|
|
void check(const Names & column_names) const;
|
|
|
|
|
|
2014-07-14 14:07:47 +00:00
|
|
|
|
/** Проверить, что все запрошенные имена есть в таблице и имеют правильные типы.
|
|
|
|
|
*/
|
|
|
|
|
void check(const NamesAndTypesList & columns) const;
|
|
|
|
|
|
|
|
|
|
/** Проверить, что все имена из пересечения names и columns есть в таблице и имеют одинаковые типы.
|
|
|
|
|
*/
|
|
|
|
|
void check(const NamesAndTypesList & columns, const Names & column_names) const;
|
|
|
|
|
|
2014-03-09 17:36:01 +00:00
|
|
|
|
/** Проверить, что блок с данными для записи содержит все столбцы таблицы с правильными типами,
|
|
|
|
|
* содержит только столбцы таблицы, и все столбцы различны.
|
|
|
|
|
* Если need_all, еще проверяет, что все столбцы таблицы есть в блоке.
|
|
|
|
|
*/
|
|
|
|
|
void check(const Block & block, bool need_all = false) const;
|
|
|
|
|
|
2014-03-19 10:45:13 +00:00
|
|
|
|
virtual ~ITableDeclaration() {}
|
2014-03-09 17:36:01 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
}
|