尝试使用astyanax客户端和RowSliceQuery编写一个查询,该查询将对列族中的所有行进行分页。
keyspace.prepareQuery(COLUMN_FAMILY).getKeyRange(null, null, null, null, 100);使用hector成功地做到了这一点,其中第一次调用是使用空的开始和结束键完成的。在检索到第一页后,我使用结果中的最后一个键来查询第二页等。这是使用hector的第一页的代码。
HFactory.createRangeSlicesQuery(keyspace,
LongSerializer.get(), new CompositeSerializer(),
BytesArraySerializer.get())
.setColumnFamily(COLUMN_FAMILY)
.setRange(null, null, false, 100).setRowCount(100);现在,当我尝试使用astyanax执行此操作时,我收到有关null和非null键和标记的错误。不确定标记在此查询中的作用。我也可以使用allRows(),但我想使用键范围查询来实现,因为它给了我更多的灵活性。
有谁有一个使用astyanax的键范围查询的例子吗?我在“入门”文档或网络上的任何其他地方都找不到一个示例。
谢谢!安东
发布于 2014-12-02 03:13:51
您所指的是getRowRange方法:
keyspace.prepareQuery(CF_STANDARD1)
.getRowRange(startKey, endKey, startToken, endToken, count)但是,请注意,这仅在使用ByteOrderedPartitioner时有效。因为默认情况下,Cassandra使用Murmur3Partitioner,所以这通常不会起作用。建议使用索引来完成此操作。Astyanax还提供了reverse index search配方,它利用了第二个列系列,该系列将键存储为列,以允许对原始数据进行有效的范围搜索。
发布于 2012-10-17 17:35:00
检查此示例代码。我希望这段代码能帮助你进行分页。
IndexQuery<String, String> query = keyspace
.prepareQuery(CF_STANDARD1).searchWithIndex()
.setRowLimit(10).autoPaginateRows(true).addExpression()
.whereColumn("Index2").equals().value(42);最好的
https://stackoverflow.com/questions/12762818
复制相似问题