ClickHouse/dbms/include/DB/Core/Block.h

81 lines
2.7 KiB
C
Raw Normal View History

2011-08-09 15:57:33 +00:00
#pragma once
2010-03-01 16:59:51 +00:00
#include <vector>
#include <map>
#include <list>
2010-03-04 19:20:28 +00:00
#include <DB/Core/ColumnWithNameAndType.h>
2011-11-06 02:29:13 +00:00
#include <DB/Core/NamesAndTypes.h>
2010-03-05 15:29:17 +00:00
#include <DB/Core/Exception.h>
#include <DB/Core/ErrorCodes.h>
2010-03-01 16:59:51 +00:00
namespace DB
{
/** Тип данных для представления подмножества строк и столбцов в оперативке.
* Содержит также метаданные (типы) столбцов и их имена.
* Позволяет вставлять, удалять столбцы в любом порядке, менять порядок столбцов.
*/
class Block
{
public:
typedef std::list<ColumnWithNameAndType> Container_t;
typedef std::vector<Container_t::iterator> IndexByPosition_t;
typedef std::map<String, Container_t::iterator> IndexByName_t;
private:
2010-03-04 19:20:28 +00:00
Container_t data;
2010-03-01 16:59:51 +00:00
IndexByPosition_t index_by_position;
IndexByName_t index_by_name;
void rebuildIndexByPosition();
public:
2010-03-12 20:44:25 +00:00
Block() {}
/// нужны, чтобы правильно скопировались индексы
Block(const Block & other);
Block & operator= (const Block & other);
2010-03-05 15:29:17 +00:00
/// вставить столбец в заданную позицию
2010-03-01 16:59:51 +00:00
void insert(size_t position, const ColumnWithNameAndType & elem);
2010-03-05 15:29:17 +00:00
/// вставить столбец в конец
void insert(const ColumnWithNameAndType & elem);
2011-09-04 05:14:52 +00:00
/// вставить столбец в конец, если столбца с таким именем ещё нет
void insertUnique(const ColumnWithNameAndType & elem);
2010-03-05 15:29:17 +00:00
/// удалить столбец в заданной позиции
2010-03-01 16:59:51 +00:00
void erase(size_t position);
ColumnWithNameAndType & getByPosition(size_t position);
const ColumnWithNameAndType & getByPosition(size_t position) const;
ColumnWithNameAndType & getByName(const std::string & name);
const ColumnWithNameAndType & getByName(const std::string & name) const;
2011-12-12 06:15:34 +00:00
bool has(const std::string & name) const;
2011-08-12 20:39:42 +00:00
size_t getPositionByName(const std::string & name) const;
2011-11-06 02:29:13 +00:00
NamesAndTypesList getColumnsList() const;
2010-03-04 19:20:28 +00:00
/** Возвращает количество строк в блоке.
* Заодно проверяет, что все столбцы кроме констант (которые содержат единственное значение),
* содержат одинаковое число значений.
*/
size_t rows() const;
size_t columns() const;
operator bool() const { return !data.empty(); }
bool operator!() const { return data.empty(); }
2011-08-14 00:49:30 +00:00
/** Получить список имён столбцов через запятую. */
std::string dumpNames() const;
2011-09-19 03:34:23 +00:00
/** Получить такой же блок, но пустой. */
Block cloneEmpty() const;
2010-03-01 16:59:51 +00:00
};
}