Как я вставляю строку со столбцом TimeUUIDType в Cassandra?

В Cassandra у меня есть следующее Семейство Столбцов:

<ColumnFamily CompareWith="TimeUUIDType" Name="Posts"/>

Я пытаюсь вставить запись в него следующим образом использование C++ сгенерированная функция, сгенерированная Экономией:

ColumnPath new_col;
new_col.__isset.column = true; /* this is required! */
new_col.column_family.assign("Posts");
new_col.super_column.assign("");
new_col.column.assign("1968ec4a-2a73-11df-9aca-00012e27a270");
client.insert("Keyspace1", "somekey", new_col, "Random Value", 1234, ONE);

Однако я получаю следующую ошибку: "UUID должны быть точно 16 байтов"

Я даже попробовал CLI Cassandra следующей командой:

set Keyspace1.Posts['somekey']['1968ec4a-2a73-11df-9aca-00012e27a270'] = 'Random Value'

но я все еще получаю следующую ошибку:

Exception null
InvalidRequestException(why:UUIDs must be exactly 16 bytes)
 at org.apache.cassandra.thrift.Cassandra$insert_result.read(Cassandra.java:11994)
 at org.apache.cassandra.thrift.Cassandra$Client.recv_insert(Cassandra.java:659)
 at org.apache.cassandra.thrift.Cassandra$Client.insert(Cassandra.java:632)
 at org.apache.cassandra.cli.CliClient.executeSet(CliClient.java:420)
 at org.apache.cassandra.cli.CliClient.executeCLIStmt(CliClient.java:80)
 at org.apache.cassandra.cli.CliMain.processCLIStmt(CliMain.java:132)
 at org.apache.cassandra.cli.CliMain.main(CliMain.java:173)
5
задан mixmasteralan 8 March 2010 в 08:14
поделиться

1 ответ

Экономия - это двоичный протокол; 16 байтов означает 16 байтов. «1968ec4a-2a73-11df-9aca-00012e27a270» составляет 36 байт. Вам нужно, чтобы ваша библиотека давала вам необработанную 16-байтовую форму.

Я сам не использую C ++, но «uuid версии 1» - это волшебная строка, которую вы хотите найти в Google при поиске библиотеки, которая может это сделать. http://www.google.com/search?q=C%2B%2B+version+1+uuid

7
ответ дан 14 December 2019 в 08:48
поделиться
Другие вопросы по тегам:

Похожие вопросы: