2

重新发布实际代码

    // cassandra is a connected org::apache::cassandra::CassandraClient
// statement is a CqlPreparedResult
// result is a CqlResult
// CF declaration is:
/*
CREATE COLUMNFAMILY xp (
  cid ascii PRIMARY KEY,
  exp4 counter,
  exp2 counter,
  exp3 counter,
  exp1 counter
) WITH
  comment='' AND
  comparator=text AND
  read_repair_chance=0.100000 AND
  gc_grace_seconds=864000 AND
  default_validation=counter AND
  min_compaction_threshold=4 AND
  max_compaction_threshold=32 AND
  replicate_on_write=True AND
  compaction_strategy_class='SizeTieredCompactionStrategy' AND
  compression_parameters:sstable_compression='org.apache.cassandra.io.compress.SnappyCompressor';
 */
std::vector<std::string> values;
values.resize(2);
values[0]="1";
values[1]="103";
cassandra->prepare_cql_query(statement,"update xp set exp2 = exp2 + ? where cid=?",Compression::NONE);
int32_t handle=statement.itemId;
try {
    cassandra->execute_prepared_cql_query(result,handle,values);
}
catch(InvalidRequestException &e) {
    cout << __LINE__ << " " << e.why << " "<< e.what() << endl;
}
// throws '?' is an invalid value, should be a long.
values.resize(1);
values[0]="103";
cassandra->prepare_cql_query(statement,"update xp set exp2 = exp2 + 1 where cid=?",Compression::NONE);
handle=statement.itemId;
cassandra->execute_prepared_cql_query(result,handle,values);
//works

所以看起来问题在于我们无法传递二进制数据。我试图传入一个包含 long 实际表示的字符串,但没有成功。当我从中读取数据时出现同样的问题,但我认为我可以管理它(扫描返回的字符串并将其一次转换一个字节作为最后的手段)

有人成功使用计数器、c++ 和 cql 吗?

4

2 回答 2

0

long 值应编码为 big-endian 64 位整数。所以试试:

values[0] = "\0\0\0\0\0\0\0\x64";

如果您打算在没有驱动程序的情况下继续使用 CQL,您将需要大量编组/解组例程来涵盖这类事情。

于 2012-05-16T15:35:11.880 回答
0

好吧,我发现我缺少正确的二进制编码。使用此函数将我的 long 转换为字符串,我成功地使用了准备好的查询

string to_counter(const long value) {
    union  {
        long    v;
        char    cc[8];
    } xx;
    xx.v=value;
    string r;
    r.assign(xx.cc,8);
    reverse(r.begin(),r.end());
    return r;
}

它是伴侣

long from_counter(const string& value) {
    union  {
        long    v;
        char    cc[8];
    } xx;
    for (size_t i=0; i < 8;++i) {
        xx.cc[7-i]=value.at(i);
    }
    return xx.v;
}

我很确定这段代码可以改进,任何建议都会受到欢迎:)

于 2012-06-15T20:37:32.250 回答