These docs are for v1.2.0. Click to read the latest docs for v1.6.

Multi-Index

Defines EOSIO Multi Index Table.

EOSIO Multi-Index API provides a C++ interface to the EOSIO database. It is patterned after Boost Multi Index Container. EOSIO Multi-Index table requires exactly a uint64_t primary key. For the table to be able to retrieve the primary key, the object stored inside the table is required to have a const member function called primary_key() that returns uint64_t. EOSIO Multi-Index table also supports up to 16 secondary indices. The type of the secondary indices could be any of:

  • uint64_t

  • uint128_t

  • uint256_t

  • double

  • long double

Parameters

  • TableName - name of the table

  • T - type of the data stored inside the table

  • Indices - secondary indices for the table, up to 16 indices is supported here

Example:

#include <eosiolib/eosio.hpp>
using namespace eosio;
class mycontract: contract {
  struct record {
    uint64_t    primary;
    uint64_t    secondary_1;
    uint128_t   secondary_2;
    uint256_t   secondary_3;
    double      secondary_4;
    long double secondary_5;
    uint64_t primary_key() const { return primary; }
    uint64_t get_secondary_1() const { return secondary_1; }
    uint128_t get_secondary_2() const { return secondary_2; }
    uint256_t get_secondary_3() const { return secondary_3; }
    double get_secondary_4() const { return secondary_4; }
    long double get_secondary_5() const { return secondary_5; }
    EOSLIB_SERIALIZE( record, (primary)(secondary_1)(secondary_2)(secondary_3)(secondary_4)(secondary_5) )
  };
  public:
    mycontract( account_name self ):contract(self){}
    void myaction() {
      auto code = _self;
      auto scope = _self;
      multi_index<N(mytable), record,
        indexed_by< N(bysecondary1), const_mem_fun<record, uint64_t, &record::get_secondary_1> >,
        indexed_by< N(bysecondary2), const_mem_fun<record, uint128_t, &record::get_secondary_2> >,
        indexed_by< N(bysecondary3), const_mem_fun<record, uint256_t, &record::get_secondary_3> >,
        indexed_by< N(bysecondary4), const_mem_fun<record, double, &record::get_secondary_4> >,
        indexed_by< N(bysecondary5), const_mem_fun<record, long double, &record::get_secondary_5> >
      > table( code, scope);
    }
}
EOSIO_ABI( mycontract, (myaction) )

Summary

MembersDescriptions
public inline multi_index(uint64_t code,uint64_t scope)load_object_by_primary_iterator
public inline uint64_t get_code() constReturns the code member property.
public inline uint64_t get_scope() constReturns the scope member property.
public inline const_iterator cbegin() constReturns an iterator pointing to the object_type with the lowest primary key value in the Multi-Index table.
public inline const_iterator begin() constReturns an iterator pointing to the object_type with the lowest primary key value in the Multi-Index table.
public inline const_iterator cend() constReturns an iterator pointing to the object_type with the highest primary key value in the Multi-Index table.
public inline const_iterator end() constReturns an iterator pointing to the object_type with the highest primary key value in the Multi-Index table.
public inline const_reverse_iterator crbegin() constReturns a reverse iterator pointing to the object_type with the highest primary key value in the Multi-Index table.
public inline const_reverse_iterator rbegin() constReturns a reverse iterator pointing to the object_type with the highest primary key value in the Multi-Index table.
public inline const_reverse_iterator crend() constReturns an iterator pointing to the object_type with the lowest primary key value in the Multi-Index table.
public inline const_reverse_iterator [rend](#rend)() const`Returns an iterator pointing to the object_type with the lowest primary key value in the Multi-Index table.
public inline const_iterator lower_bound (uint64_t primary) constSearches for the object_type with the lowest primary key that is greater than or equal to a given primary key.
public inline const_iterator upper_bound (uint64_t primary) constSearches for the object_type with the highest primary key that is less than or equal to a given primary key.
public inline uint64_t available_primary_key() constReturns an available primary key.
public template<>
inline auto get_index()
Returns an appropriately typed Secondary Index.
public template<>
inline auto get_index() const
Returns an appropriately typed Secondary Index.
public inline const_iterator iterator_to(const T & obj) constReturns an iterator to the given object in a Multi-Index table.
public template<>
inline const_iterator emplace(uint64_t payer,Lambda && constructor)
Adds a new object (i.e., row) to the table.
public template<>
inline void modify(const_iterator itr,uint64_t payer,Lambda && updater)
Modifies an existing object in a table.
public template<>
inline void modify(const T & obj,uint64_t payer,Lambda && updater)
Modifies an existing object in a table.
public inline const T & get(uint64_t primary,const char * error_msg) constRetrieves an existing object from a table using its primary key.
public inline const_iterator find(uint64_t primary) constSearch for an existing object in a table using its primary key.
public inline const_iterator erase(const_iterator itr)Remove an existing object from a table using its primary key.
public inline void erase(const T & obj)Remove an existing object from a table using its primary key.
typedef const_reverse_iteratorstruct multi_index::const_iterator

Members

public inline multi_index(uint64_t code,uint64_t scope)

load_object_by_primary_iterator

Constructs an instance of a Multi-Index table.

Parameters

  • code - Account that owns table

  • scope - Scope identifier within the code hierarchy

Precondition

code and scope member properties are initialized

Post Condition

each secondary index table initialized

Post Condition

Secondary indices are updated to refer to the newly added object. If the secondary index tables do not exist, they are created.

Post Condition

The payer is charged for the storage usage of the new object and, if the table (and secondary index tables) must be created, for the overhead of the table creation.

Notes The [eosio::multi_index](#eosio::multi_index) template has template parameters <uint64_t TableName, typename T, typename... Indices>, where:

  • TableName is the name of the table, maximum 12 characters long, characters in the name from the set of lowercase letters, digits 1 to 5, and the "." (period) character;

  • T is the object type (i.e., row definition);

  • Indices is a list of up to 16 secondary indices.

  • Each must be a default constructable class or struct

  • Each must have a function call operator that takes a const reference to the table object type and returns either a secondary key type or a reference to a secondary key type

  • It is recommended to use the eosio::const_mem_fun template, which is a type alias to the boost::multi_index::const_mem_fun. See the documentation for the Boost const_mem_fun key extractor for more details.

Example:

#include <eosiolib/eosio.hpp>
using namespace eosio;
using namespace std;
class addressbook: contract {
  struct address {
     uint64_t account_name;
     string first_name;
     string last_name;
     string street;
     string city;
     string state;
     uint64_t primary_key() const { return account_name; }
     EOSLIB_SERIALIZE( address, (account_name)(first_name)(last_name)(street)(city)(state) )
  };
  public:
    addressbook(account_name self):contract(self) {}
    typedef eosio::multi_index< N(address), address > address_index;
    void myaction() {
      address_index addresses(_self, _self); // code, scope
    }
}
EOSIO_ABI( addressbook, (myaction) )