4

我们有一个只有大约 1000 行的 CF。astyanax 有没有办法读取所有 1000 行?节俭甚至支持吗?

谢谢,院长

4

1 回答 1

3

您可以使用节俭调用 get_range_slices 读取所有行。请注意,它以标记顺序返回行,而不是键顺序。因此,可以读取所有行,但不能跨行键执行范围。

您可以通过 getAllRows() 在 Astyanax 中使用它。这是一些示例代码(从https://github.com/Netflix/astyanax/wiki/Reading-Data#iterate-all-rows-in-a-column-family的文档中复制)

Rows<String, String>> rows;
try {
    rows = keyspace.prepareQuery("ColumnFamilyName")
        .getAllRows()
        .setBlockSize(10)
        .withColumnRange(new RangeBuilder().setMaxSize(10).build())
        .setExceptionCallback(new ExceptionCallback() {
             @Override
             public boolean onException(ConnectionException e) {
                 try {
                     Thread.sleep(1000);
                 } catch (InterruptedException e1) {
                 }
                 return true;
             }})
        .execute().getResult();
} catch (ConnectionException e) {
}

// This will never throw an exception
for (Row<String, String> row : rows.getResult()) {
    LOG.info("ROW: " + row.getKey() + " " + row.getColumns().size());
}

这将返回每行的前 10 列,以 10 行为一组。增加传递给 RangeBuilder().setMaxSize 的数字以获取更多(或更少)列。

于 2013-07-15T20:31:55.827 回答