0

我想读取 Cassandra 中给定键空间和列族的所有数据类型的行。要读取数据,我尝试使用 CQL,如下所示

CqlQuery<String, String, ByteBuffer> cqlQuery = new CqlQuery<String, String, ByteBuffer>(keyspaceOperator, se, se, be);

cqlQuery.setQuery("select * from colfam1");

QueryResult<CqlRows<String, String, ByteBuffer>> result = cqlQuery.execute();

甚至我也尝试过使用 Hector 切片查询 API

 Cluster cluster = HFactory.getOrCreateCluster("Test Cluster", "localhost:9160");

 Keyspace keyspace = HFactory.createKeyspace("rajesh", cluster);
    SliceQuery<String, String, String> sliceQuery = HFactory.createSliceQuery(keyspace, stringSerializer, stringSerializer, stringSerializer);
    sliceQuery.setColumnFamily("colfam1").setKey("key123");
    sliceQuery.setRange("", "", false, 4);

 QueryResult<ColumnSlice<String, String>> result = sliceQuery.execute(); 

但在这两种方式中,我都能够读取所有行,但我无法读取数据类型。

任何人都可以帮助我使用 java 读取具有来自 cassandra 的数据类型的行值。??

4

1 回答 1

0

读取具有值的行非常简单。但我也想阅读元数据。这是解决方案

public Map<String, ArrayList<String>>  getMetaData(Client _client, String _keyspace) throws SQLException, NotFoundException, InvalidRequestException, TException{
    ArrayList<String> columnfamilyNames = new ArrayList<String>();
    ArrayList<String> columnNames = new ArrayList<String>();
    ArrayList<String> validationClasses = new ArrayList<String>();
    Map<String, ArrayList<String>> metadataMapList =new HashMap<String,ArrayList<String>>();
    KsDef keyspaceDefinition = _client.describe_keyspace(_keyspace);
    List<CfDef> columnDefinition = keyspaceDefinition.getCf_defs();
    for(int i=0;i<columnDefinition.size();i++){
        List<ColumnDef> columnMetadata = columnDefinition.get(i).getColumn_metadata();
        for(int j=0;j<columnMetadata.size();j++){
            columnfamilyNames.add(columnDefinition.get(i).getName());
            columnNames.add(new String((columnMetadata.get(j).getName())));
            validationClasses.add(columnMetadata.get(j).getValidation_class());
        }
    }
    metadataMapList.put("columnfamilyName", columnfamilyNames);
    metadataMapList.put("ColumnName", columnNames);
    metadataMapList.put("validationClass", validationClasses);
    return metadataMapList;
}

仅供参考这里我使用节俭客户端。

于 2013-03-07T11:16:04.577 回答