Table

Table is a database object that holds a list of vectors in a given order. This section describes how to create, access, and modify tables, along with examples.

Creating Tables

The DolphinDB C++ API provides two methods (createTable defined in the header <Util.h>) for creating tables:

(1) The following is the syntax to declare a table with names and data types specified for each column:

static Table* createTable(const vector<string>& colNames, const vector<DATA_TYPE>& colTypes, INDEX size, INDEX capacity, const vector<int>& extraParams = {});

Arguments

  • colNames: The names for each column.
  • colTypes: The data types for each column.
  • size: The initial size (in terms of the number of rows) of the table.
  • capacity: The amount of memory (in terms of the number of rows) allocated to the table.
  • extraParam: It determines the scale for values in a matrix of DECIMAL type.

Examples

vector<string> colNames{"col1", "col2", "col3"};
vector<DATA_TYPE> colTypes{DT_INT, DT_BOOL, DT_STRING};
TableSP tbl = Util::createTable(colNames, colTypes, 0, 100);

(2) The following is the syntax to declare a table with names and vectors specified for each column:

static Table* createTable(const vector<string>& colNames, const vector<ConstantSP>& cols);

Arguments

  • colNames: The names for each column.
  • colTypes: A list of vectors, where each vector defines the values for a single column. Note that all vectors must be of the same length.

Examples

vector<string> colNames{"col1", "col2", "col3"};
vector<ConstantSP> cols;
cols.emplace_back(Util::createVector(DT_INT, 0));
cols.emplace_back(Util::createVector(DT_BOOL, 0));
cols.emplace_back(Util::createVector(DT_STRING, 0));
TableSP tbl = Util::createTable(colNames, cols);

Accessing Tables

The DolphinDB C++ API provides two methods to retrieve data from a table:

(1) By column

Use function getColumn to obtain a vector (i.e., a column) from the table. For further retrieving entries from a column, see Accessing Vectors. The function declarations are as follows:

ConstantSP getColumn(const string& name) const;           //get the column with the name 'name'
ConstantSP getColumn(INDEX index) const;                  //get the index (starts at 0) column

Examples

VectorSP col1 = tbl->getColumn(0);        // get the first column (with index 0)
VectorSP col2 = tbl->getColumn("col2");   // get the column with name 'col2'

(2) By row

There are two ways to retrieve data from a table by row.

a. Use the get function to get the index (starts at 0) row of the table. It returns a dictionary with column names as keys and entry values as values. The function declaration is as follows:

ConstantSP get(INDEX index) const;

Examples

DictionarySP row = tbl->get(0);
std::cout << row->getMember("col1")->getInt() << std::endl;
std::cout << row->getMember("col3")->getString() << std::endl;

b. Use class ResultSet defined in the header <Util.h>.

ResultSet resultSet(tbl);
while (!resultSet.isAfterLast()) {
        int colIndex = 0;
        std::cout << resultSet.getInt(colIndex++) << " ";
        std::cout << int(resultSet.getBool(colIndex++)) << " ";
        std::cout << resultSet.getString(colIndex++) << std::endl;
        resultSet.next();
}

Appending Data to a Table

The DolphinDB C++ API provides two methods for appending data to a vector:

(1) Use the append function to add rows to the end of a table. The function declaration is as follows:

bool append(vector<ConstantSP>& values, INDEX& insertedRows, string& errMsg);

Arguments

  • values: In-parameter. The values to be appended. It can be a list of equal-length vectors with data types matching each column, or a table with identical schema to the original table.
  • insertedRows: Out-parameter. The number of rows that have been successfully inserted.
  • errMsg: Out-parameter. The error message for the failed insert operation.

Return Values

A boolean value indicating whether data is appended successfully.

Examples

INDEX insertedRows;
std::string errorMsg;
VectorSP col0 = Util::createVector(DT_INT, 0);
VectorSP col1 = Util::createVector(DT_BOOL, 0);
VectorSP col2 = Util::createVector(DT_STRING, 0);
col0->append(Util::createInt(1));
col1->append(Util::createBool(true));
col2->append(Util::createString("123"));
vector<ConstantSP> values{col0, col1, col2};
tbl->append(values, insertedRows, errorMsg);                  //values is a list of vectors, where each vector corresponds to 'col0', 'col1', 'col2'
    
TableSP tbl2 = tbl->getValue();
values= {tbl2};
tbl->append(values, insertedRows, errorMsg);                //values is a table

(2) Use the getColumn function to obtain vectors (i.e., a columns) from the table, append data to each vector, and then call the BasicTable::updateSize() function to update the number of rows.

Example

VectorSP col0 = tbl->getColumn(0);
VectorSP col1 = tbl->getColumn(1);
VectorSP col2 = tbl->getColumn(2);

col0->append(Util::createInt(1));
col1->append(Util::createBool(true));
col2->append(Util::createString("123"));
dynamic_cast<BasicTable*>(tbl.get())->updateSize();