【问题标题】:How do I insert a row with a TimeUUIDType column in Cassandra?如何在 Cassandra 中插入带有 TimeUUIDType 列的行?
【发布时间】:2010-04-23 17:37:13
【问题描述】:

在 Cassandra 中,我有以下列族:

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

我正在尝试使用 Thrift 生成的 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 个字节”

我什至用以下命令尝试过 Cassandra CLI:

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)

【问题讨论】:

    标签: cassandra uuid thrift


    【解决方案1】:

    Thrift 是一个二进制协议; 16 字节表示 16 字节。 “1968ec4a-2a73-11df-9aca-00012e27a270”是 36 个字节。您需要让您的库为您提供原始的 16 字节格式。

    我自己不使用 C++,但“版本 1 uuid”是您在寻找可以执行此操作的库时想用谷歌搜索的神奇字符串。 http://www.google.com/search?q=C%2B%2B+version+1+uuid

    【讨论】:

      猜你喜欢
      • 1970-01-01
      • 2019-03-04
      • 2016-07-06
      • 2013-07-26
      • 2016-11-27
      • 1970-01-01
      • 2015-04-19
      • 1970-01-01
      • 2016-05-28
      相关资源
      最近更新 更多