首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >Astyanax键范围查询

Astyanax键范围查询
EN

Stack Overflow用户
提问于 2012-10-07 02:53:23
回答 2查看 1.6K关注 0票数 3

尝试使用astyanax客户端和RowSliceQuery编写一个查询,该查询将对列族中的所有行进行分页。

代码语言:javascript
复制
keyspace.prepareQuery(COLUMN_FAMILY).getKeyRange(null, null, null, null, 100);

使用hector成功地做到了这一点,其中第一次调用是使用空的开始和结束键完成的。在检索到第一页后,我使用结果中的最后一个键来查询第二页等。这是使用hector的第一页的代码。

代码语言:javascript
复制
HFactory.createRangeSlicesQuery(keyspace,
LongSerializer.get(), new CompositeSerializer(),
BytesArraySerializer.get())
.setColumnFamily(COLUMN_FAMILY)
.setRange(null, null, false, 100).setRowCount(100);

现在,当我尝试使用astyanax执行此操作时,我收到有关null和非null键和标记的错误。不确定标记在此查询中的作用。我也可以使用allRows(),但我想使用键范围查询来实现,因为它给了我更多的灵活性。

有谁有一个使用astyanax的键范围查询的例子吗?我在“入门”文档或网络上的任何其他地方都找不到一个示例。

谢谢!安东

EN

回答 2

Stack Overflow用户

发布于 2014-12-02 03:13:51

您所指的是getRowRange方法:

代码语言:javascript
复制
keyspace.prepareQuery(CF_STANDARD1)
  .getRowRange(startKey, endKey, startToken, endToken, count)

但是,请注意,这仅在使用ByteOrderedPartitioner时有效。因为默认情况下,Cassandra使用Murmur3Partitioner,所以这通常不会起作用。建议使用索引来完成此操作。Astyanax还提供了reverse index search配方,它利用了第二个列系列,该系列将键存储为列,以允许对原始数据进行有效的范围搜索。

票数 0
EN

Stack Overflow用户

发布于 2012-10-17 17:35:00

检查此示例代码。我希望这段代码能帮助你进行分页。

代码语言:javascript
复制
IndexQuery<String, String> query = keyspace
   .prepareQuery(CF_STANDARD1).searchWithIndex()
   .setRowLimit(10).autoPaginateRows(true).addExpression()
   .whereColumn("Index2").equals().value(42);

最好的

票数 -1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/12762818

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档