如何在Hbase中获取给定行键的一部分的所有行

时间:2013-05-10 06:04:33

标签: java database eclipse hbase

我在Hbase中有以下表结构:

Row               column+cell

Mary_Ann_05/10/2013 column=cf:verified, timestamp=234454454,value=2,2013-02-12  
Mary_Ann_06/10/2013 column=cf:verified, timestamp=2345454454,value=3,2013-02-12 
Mary_Ann_07/10/2013 column=cf:verified, timestamp=2345454522454,value=4,2013-02-12 
Mary_Ann_08/10/2013 column=cf:verified, timestamp=23433333454,value=1,2013-12-12 

我想使用java检索以Mary_Ann开头的所有记录。我该怎么做?

1 个答案:

答案 0 :(得分:3)

您可以使用PrefixFilter实现这一目标。给定在实例化过滤器实例时指定的前缀,将匹配此前缀的所有行返回给客户端。构造函数是:public PrefixFilter(byte[] prefix)

用法:

Filter filter = new PrefixFilter(Bytes.toBytes("Mary_Ann"));
Scan scan = new Scan();
scan.setFilter(filter);
ResultScanner scanner = table.getScanner(scan);
for (Result result : scanner) {
     for (KeyValue kv : result.raw()) {
        System.out.println("KV: " + kv + ", Value: " +
        Bytes.toString(kv.getValue()));
     }
}
scanner.close();

HTH