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>
|
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);
|
|
|
|
|
/// удалить столбец в заданной позиции
|
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;
|
|
|
|
|
|
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(); }
|
2010-03-01 16:59:51 +00:00
|
|
|
|
};
|
|
|
|
|
|
|
|
|
|
}
|