названий и типов столбцов, и сколько-то строк данных соответствующих типов. В голову приходит разве что вектор векторов юнионов
во-первых, надо оформить в нормальные сущности, а не плодить трёхэтажные vector<vector<foo<bar<...
вопрос интересный. в свое время я начинал пет проект по представлению реляционных данных в памяти. остались эскизы из TDD по типу: // определить домен auto STRING = std::make_shared<domain>(L"string", string(L"default_value")); // определить отношение table r{ {L"name", STRING}, {L"surname", STRING}, }; // способы добавления кортежа: // 1. добавление, как списка пар (имя атрибута, значение) r.append({{L"name", string(L"ivan")}, {L"surname", string(L"ivanov")}}); // 2. добавление, как списка пар (индекс атрибута, значение) r.append({{0, string(L"petr")}, {1, string(L"petrov")}}); // 3. добавление, как списка значений атрибутов в порядке их // объявления в схеме r.append({string(L"sidor"), string(L"sidorov")});
а ты случайно не из самары7
json
о, действительно, нужно попробовать
я правильно понимаю, что domain внутри себя как-то ассоциирует тип string со строкой "string" ?
он хранит std::type_info, выводит либо по типу, либо по default value: / * @brief The domain class is base class for all domains. * The domain determines value type and restrictions on value set. */ class domain { public: // structors / * @brief domain constructs domain object based on the base_type domain * base type. * @param base_type domain base type */ domain(string_view name, std::type_info const &base_type) : name_{name}, base_type_{&base_type} {} template <typename T> domain(string_view name, T &&default_value) : name_{name}, base_type_{&typeid(default_value)}, default_value_{std::forward<T>(default_value)} {} domain(domain const &) = default; domain(domain &&) = default; domain &operator=(domain const &) = default; domain &operator=(domain &&) = default; virtual ~domain() = default; public: // getters / * @brief name returns domain name * @return domain name */ string const &name() const { return name_; } / * @brief base_type returns domain base type * @return domain base type */ std::type_info const &base_type() const { return *base_type_; } / * @brief default_value returns default value * @return default value */ optional<value> const &default_value() const { return default_value_; } public: // modifiers / * @brief get_or_add gets or adds the v value * @param v value * @return value pointer */ value_ptr get_or_add(value v) { if (*base_type_ != v.type()) { // FIXME: try to convert value to domain type throw invalid_value_type_exception{ L"domain::get_or_add", (boost::wformat( L"Cannot resolve value: The value type is not compatible " L"with the %s domain type") % name_) .str()}; } return dictionary_.get_or_add(std::move(v)); } ...
Вектор векторов вариантов.
Обсуждают сегодня