我已经在本地设置了一个节点集群。现在我正在尝试从 Cassandra 读取数据。我是 Astyanax(Cassandra 的 Netflix 客户端)的新手。
目前我所看到的是 - 您可以在 rowkey 上请求数据基础。基于rowkey的含义我可以检索所有不是我想要的列。
但我正在寻找的是 - 我将拥有 rowkey 和几个 columnNames。因此,基于该行键,我只需要检索这些列。像这样的东西-
SELECT colA, colB from table1 where rowkey = "222";
以下是我基于行键检索所有列名的方法。如何在给定行键的情况下仅检索选定的列?
public void read(final String userId, final Collection<String> columnNames) {
    OperationResult<ColumnList<String>> result;
    try {
        result = CassandraConnection.getInstance().getKeyspace().prepareQuery(CassandraConnection.getInstance().getEmp_cf())
                .getKey(userId)
                .execute();
        ColumnList<String> cols = result.getResult();
        for(Iterator<Column<String>> i = cols.iterator(); i.hasNext(); ) {
            Column<String> c = i.next();
            Object v = null;
            if(c.getName().endsWith("id")) // type induction hack
                v = c.getIntegerValue();
            else
                v = c.getStringValue();
            System.out.println("- col: '"+c.getName()+"': "+v);
        }
    } catch (ConnectionException e) {
        System.out.println("failed to read from C*" +e);
        throw new RuntimeException("failed to read from C*", e);
    }
}
在上面的代码中,Collection<String> columnNames我想要请求的列名很少。
谁能告诉我我需要在上述方法中进行哪些更改?