2

有没有办法通过phpcassa使用子句从 cassandra 获取数据?

我需要选择所有行sum<10。例如,phpcassa 中的函数只get_range() 选择等于某些值的行。

4

1 回答 1

2

通常使用 PHPCassa,你会使用索引:

根据http://thobbs.github.com/phpcassa/tutorial.html // 略有增强:

<?php
$column_family = new ColumnFamily($conn, 'Indexed1');
$index_exp_eq = CassandraUtil::create_index_expression('gender', 'male', $op='EQ');
$index_exp_gt = CassandraUtil::create_index_expression('sum', 10, $op='GT');
$index_clause = CassandraUtil::create_index_clause(array($index_exp_eq, $index_exp_gt));
$rows = $column_family->get_indexed_slices($index_clause);
// returns an Iterator over:
//    array('winston smith' => array('birthdate' => 1984))

foreach($rows as $key => $columns) {
    // Do stuff with $key and $columns
    Print_r($columns)
}
?>

在您的方案中,您不能简单地使用 sum<10 的单个索引表达式......您必须拥有带有 EQ 运算符的第一个索引表达式和带有其他运算符的后续索引表达式。

于 2011-11-11T15:14:32.327 回答