Я начал работать с C++ libcql
библиотека для Cassandra .. Я пытаюсь получить данные из Cassandra, используя C ++ с библиотекой libcql ..
Всякий раз, когда я иду в командной строке, используя cqlsh
и выберите, как это —
select records from profile_user where user_id = '1';
Я всегда получаю вывод ниже в командной строке cql и в котором records
столбец на самом деле map
в котором ключ e1
и значение HELLO
, Точно так же ключ e2
и значение HELLO
снова .. Когда я создал таблицу в CQL, я создал записи в виде карты, так как я использовал функцию сбора в CQL ..
records
--------------------------------
{'e1': 'HELLO', 'e2': 'HELLO'}
Сейчас переходим на мир C ++
Теперь я пытаюсь извлечь то же самое из C++ libcql library
… Я буду выполнять тот же запрос выбора выше в C ++, и я хочу вернуть карту, которая будет иметь e1, e2 as the key
а также HELLO as there value inside that map
… можно это сделать в C ++?
/**
* This method will retrieve the data from Cassandra..
* And then call print_rows method to print it out on the console
*/
void get_attributes(string id){
try{
// some code
//Connection open
connection_open();
execute_query("USE testks;");
//this will give me the result back of the select query
cql_result_t& result = execute_query("select * from profile_user where key ='"+id+"';");
// and this is printing it out on the console
print_rows(result);
// some code
} catch (int e){
// some code here
}
}
Ниже приведен метод, который выводит результаты на консоль после запуска моей программы на C ++ —
/**
* This method prints out the result on the console.. *
*
*/
void print_rows(cql::cql_result_t& result) {
while (result.next()) {
for (size_t i = 0; i < result.column_count(); ++i) {
cql::cql_byte_t* data = NULL;
cql::cql_int_t size = 0;
result.get_data(i, &data, size);
std::cout.write(reinterpret_cast<char*>(data), size);
std::cout << " | ";
}
std::cout << std::endl;
}
}
Результат, который я вижу на консоли после запуска моей вышеупомянутой программы на C ++, выглядит примерно так:
e1HELLOe2HELLO |
Но то, что я ищу, — Сохраните результат в Map в C ++ таким образом, чтобы ключ был e1 and e2
на карте .. И значение для них должно быть HELLO
в той же карте … а затем итерации карты и распечатать результат в C ++? Это возможно сделать с текущим кодом, который у меня есть?
Если да, может ли кто-нибудь привести простой пример по этому вопросу? Спасибо…
По сути, это вопрос C ++. Просто извлеките данные и поместите их в карту … Но проблема, с которой я сталкиваюсь, заключается в том, что мой опыт полностью связан с Java, поэтому у меня немного трудных моментов, чтобы понять, как это сделать. ..
Я не знаю libcql
и я не смог найти какую-либо документацию. Глядя на заголовок для cql_result_t
указывает на наличие функций для определения количества столбцов и способов доступа к ним. Судя по всему, вы просто скопировали демонстрационный пример, который, кажется, не является особенно хорошим демо. Я бы начал с уточнения print_result()
Функция выглядит примерно так, как показано ниже, и посмотреть, что я получу. мой Угадай заключается в том, что вы получаете тип «карта» из вашего запроса, и вам нужно будет узнать, как извлечь и использовать соответствующее представление, просматривая их заголовки (если только нет какой-либо документации). Приведенный ниже код просто извлекает несколько типов и в основном печатает, что ему нужно для обработки соответствующего типа (при условии, что он на самом деле компилируется):
void print_result(cql::cql_result_t& result)
{
std::size_t const columns(result.column_count());
while (result.next()) {
for (std::size_t column(0); column != columns; ++column) {
cql::cql_column_type_enum type;
if (result.column_type(column, type)) {
switch (type) {
case cql::CQL_COLUMN_TYPE_CUSTOM:
std::cout << "todo: process custom type\n";
break;
case cql::CQL_COLUMN_TYPE_ASCII:
std::cout << "todo: process ascii type\n";
break;
case cql::CQL_COLUMN_TYPE_BIGINT:
std::cout << "todo: process bigint type\n";
break;
case cql::CQL_COLUMN_TYPE_BLOB:
std::cout << "todo: process blob type\n";
break;
case cql::CQL_COLUMN_TYPE_BOOLEAN:
std::cout << "todo: process boolean type\n";
break;
case cql::CQL_COLUMN_TYPE_COUNTER:
std::cout << "todo: process counter type\n";
break;
case cql::CQL_COLUMN_TYPE_DECIMAL:
std::cout << "todo: process decimal type\n";
break;
case cql::CQL_COLUMN_TYPE_DOUBLE: {
double value;
if (result.get_double(column, value)) {
std::cout << "column=" << column << " "<< "double=" << value << "\n";
}
else {
std::cout << "failed to extract double for column "<< column << "\n";
}
break;
case cql::CQL_COLUMN_TYPE_FLOAT: {
float value;
if (result.get_float(column, value)) {
std::cout << "column=" << column << " "<< "float=" << value << "\n";
}
else {
std::cout << "failed to extract float for column "<< column << "\n";
}
break;
case cql::CQL_COLUMN_TYPE_INT: {
int value;
if (result.get_int(column, value)) {
std::cout << "column=" << column << " "<< "int=" << value << "\n";
}
else {
std::cout << "failed to extract int for column "<< column << "\n";
}
break;
case cql::CQL_COLUMN_TYPE_TEXT: {
std::string value;
if (result.get_string(column, value)) {
std::cout << "column=" << column << " "<< "text='" << value << "'\n";
}
else {
std::cout << "failed to extract text for column "<< column << "\n";
}
break;
case cql::CQL_COLUMN_TYPE_TIMESTAMP:
std::cout << "todo: process timestamp type\n";
break;
case cql::CQL_COLUMN_TYPE_UUID:
std::cout << "todo: process uiid type\n";
break;
case cql::CQL_COLUMN_TYPE_VARCHAR:
std::cout << "todo: process varchar type\n";
break;
case cql::CQL_COLUMN_TYPE_VARINT:
std::cout << "todo: process varint type\n";
break;
case cql::CQL_COLUMN_TYPE_TIMEUUID:
std::cout << "todo: process timeuuid type\n";
break;
case cql::CQL_COLUMN_TYPE_INET:
std::cout << "todo: process inet type\n";
break;
case cql::CQL_COLUMN_TYPE_LIST:
std::cout << "todo: process list type\n";
break;
case cql::CQL_COLUMN_TYPE_MAP:
std::cout << "todo: process map type\n";
break;
case cql::CQL_COLUMN_TYPE_SET:
std::cout << "todo: process set type\n";
break;
}
}
}
}
}
У cql_result_t есть метод get_map. Используйте get_map вместо get_data:
cql::cql_result_t *r;
cql::cql_map_t *props = 0;
if (!r->get_map("records", &props)) {
delete props;
// throw an error
}
std::auto_ptr<cql::cql_map_t> p(props);
std::map<std::string, std::string> m;
for (std::size_t i = 0; i < p->size(); ++i) {
std::string key;
if (!p->get_key_string(i, key))
// throw an error
std::string value;
if (!p->get_value_string(i, value))
// throw an error
m.insert(std::make_pair(key, value));
}